pggen
A database first code generator focused on postgres (by opendoor)
sqlparser-rs
Extensible SQL Lexer and Parser for Rust (by sqlparser-rs)
Our great sponsors
pggen | sqlparser-rs | |
---|---|---|
2 | 12 | |
58 | 2,434 | |
- | 5.0% | |
0.6 | 9.3 | |
about 1 month ago | 1 day ago | |
Go | Rust | |
MIT License | Apache License 2.0 |
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
pggen
Posts with mentions or reviews of pggen.
We have used some of these posts to build our list of alternatives
and similar projects. The last one was on 2021-09-08.
-
We Went All in on Sqlc/Pgx for Postgres and Go
If you want a code generator like this that has support for that kind of thing, https://github.com/opendoor/pggen can automatically infer these kinds of relationships based on foreign key relationships and emit slices of pointers to connect the records together in memory. It can even figure out 1-1 relationships if there is a UNIQUE index on the foreign key. There is a little mini-DSL for specifying exactly how much of the transitive closure of a given record you want to get filled in for you.
sqlparser-rs
Posts with mentions or reviews of sqlparser-rs.
We have used some of these posts to build our list of alternatives
and similar projects. The last one was on 2023-07-04.
-
Introducing SQLPage : write websites entirely in SQL
sqlparser to parse SQL queries and detect variable bindings
-
Understanding the SQL AST and what can be done with it
So to start with this, I looked into SQL parsing and found this library https://github.com/sqlparser-rs/sqlparser-rs
-
Supabase Logs: open source logging server
We switched to an open source alternative, the rust-based sqlparser-rs library, contributing a few updates for the BigQuery dialect.
- Parsing SQL with Rust
-
Writing a SQL LS in Rust - Looking for Coding Companions.
I have experience with sqlparser-rs (for my sqlpage project), but it does not track the source code location of the parsed data structures (yet).
-
Pure Python Distributed SQL Engine
It uses https://github.com/sqlparser-rs/sqlparser-rs as the parser and lexer. The binder, planner, optimizer and executor are in Python. The optimizer stage only works on the logical plan and the rules are heuristic only.
-
Parsing / Recursive Descent Parser
That code could be copied directly from some real-world examples - sqlparser-rs code looks pretty much exactly the same.
https://github.com/sqlparser-rs/sqlparser-rs
-
RisingLight is an OLAP database system for educational purpose
Also neat to find the SQL parser library they use.
- We Went All in on Sqlc/Pgx for Postgres and Go
- “Swift is the only language I could find with over 100 keywords”
What are some alternatives?
When comparing pggen and sqlparser-rs you can also consider the following projects:
pggen - Generate type-safe Go for any Postgres query. If Postgres can run the query, pggen can generate code for it.
sled - the champagne of beta embedded databases
goqu - SQL builder and query library for golang
goyesql - Parse SQL files with multiple named queries and automatically prepare and scan them into structs.
sqlite
gnorm - A database-first code generator for any language
kube - Rust Kubernetes client and controller runtime
proteus - A simple tool for generating an application's data access layer.
prettytable-rs - A rust library to print aligned and formatted tables
ccgo
go - The Go programming language