Prequel.QueryEngine
0.1.2
dotnet add package Prequel.QueryEngine --version 0.1.2
NuGet\Install-Package Prequel.QueryEngine -Version 0.1.2
<PackageReference Include="Prequel.QueryEngine" Version="0.1.2" />
paket add Prequel.QueryEngine --version 0.1.2
#r "nuget: Prequel.QueryEngine, 0.1.2"
// Install Prequel.QueryEngine as a Cake Addin #addin nuget:?package=Prequel.QueryEngine&version=0.1.2 // Install Prequel.QueryEngine as a Cake Tool #tool nuget:?package=Prequel.QueryEngine&version=0.1.2
Prequel - C# SQL Query Engine
Prequel is a SQL query engine built in C#. The goal of this project is to demonstrate how query engines are built, and to bring a query engine to the .NET community.
The project contains a step-by-step overview explaining how database query engines are built. The project is also available as a NuGet package and can be integrated into your project to support querying virtually any source where data can be collected.
The project contains several example data sources including CSV, Avro, Parquet, JSON, MS Sql, etc.. Adding new data sources is trivial and allows any data source to be queried with SQL, even querying data across disparate sources (e.g. join JSON to CSV or tables in a RDBMS instance).
π Getting Started
Open the source code in your IDE of choice. Set the Prequel.Console as the startup project and/or compile the project and run. The sample project will run example SQL queries and output the results to the console.
Visual Studio, Rider - Set Prequel.Console as the startup project and run the project
VS Code - Use the included launch profile, run from the "RUN AND DEBUG" window
CLI - Open a terminal to the projects root
cd src/Tests/Prequel.Console dotnet run
NuGet
dotnet add package Prequel.QueryEngine
What is a Query Engine?
A query engine is software that interprets a query (Structured Query Language) and interacts with a data source to manipulate the underlying data. Take a look at the full project overview for details on how every part of a query engine works.
β¨ Features
- π€² Simple: Query engines are not simple by nature. However this project uses the lowest common denominator approach to standardize unrelated data sources and data types (e.g. JSON vs CSV).
- 𧩠Extensible: Plug in any data source. All runtime data is queried from your data source under your control.
- π΅ Caching: In-memory and durable caching options make it simple to control how and when your data source is read.
- π Open Source: All code and features are available, transparent, and free to use.
- ποΈ Performant: Queries are optimized before execution with minimum-data-needed approach to reading data. Only the data required is read from data sources, even across unrelated sources.
- π Metrics: Profiling is built into the engine.
SQL Support
-
SELECT
-
*
Wildcards - Scalar values
-
JOIN
- inner/right/left/full/cross -
GROUP BY
-
HAVING
-
UNION
-
LIMIT
-
LIKE
,ILIKE
substring comparisions -
IN
,NOT IN
list comparisions - Subqueries
- Aggregations -
min
/max
/stddev
/etc... - Math opperations
-
CAST
functions -
EXPLAIN
plans -
EXCLUDE
/EXCEPT
- Not yet implemented -
INSERT
,UPDATE
,DROP
operations
Motivation
This project contains a full overview of how query engines are built. Part of the goal with this project is to demonstrate the mechanics of a query engine. Chances are you use some form of database, BI tool, or ETL process as part of your daily development. While the code here is fully functional, itβs also academic in the sense that it gives a full picture of how data is gathered, aggregated, sorted, filtered, and so on, by your favorite data engine. Whether Postgres, MySql, BigQuery, Snowflake, or any of the dozens of database systems or cloud-hosted data platforms.
Contribution
Contributions are what make open-source work. We greatly appreciate any contributions. Thank you for being a part of the community! π₯°
Sponsorship
If you find Prequel useful, or the tutorial helpful, please consider sponsoring us. Your support will help the project continue to grow.
β Your Name Here β if you become a sponsor π.
<a href="https://buymeacoffee.com/tylerbrinks" target="_blank"><img src="https://www.buymeacoffee.com/assets/img/custom_images/orange_img.png" alt="Buy Me A Coffee" ></a>
Other Projects
C# SqlParser - SQL Grammar Parser
License
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
-
net8.0
- SqlParserCS (>= 0.5.7)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
0.1.2 | 91 | 12/2/2024 |
0.1.2-release0000 | 66 | 12/2/2024 |
0.1.1 | 91 | 11/29/2024 |
0.1.1-release0000 | 72 | 11/29/2024 |
0.1.0 | 85 | 11/29/2024 |