sqddl
sqddl is a zero-configuration database migration tool. (by bokwoon95)
ent
An entity framework for Go (by facebook)
sqddl | ent | |
---|---|---|
6 | 145 | |
14 | 14,975 | |
- | 1.3% | |
5.4 | 8.1 | |
about 2 months ago | 7 days ago | |
Go | Go | |
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.
sqddl
Posts with mentions or reviews of sqddl.
We have used some of these posts to build our list of alternatives
and similar projects. The last one was on 2022-12-25.
-
Advice needed for generating schema-struct diff
My CLI tool sqddl is exactly what you're asking for. Check out https://bokwoon.neocities.org/sqddl#automigrate.
-
Data Version Control?
https://github.com/bokwoon95/sqddl (However you need to install Go)
-
Golang Postgres Schema Builder?
Oh hey, do I have the package for you. My package (https://github.com/bokwoon95/sqddl) converts a slice of ddl.Table structs into working DDL. Check it out:
-
Golang equivalent of C# Entity framework?
Represent tables using structs: https://github.com/bokwoon95/sqddl/blob/main/ddl/testdata/tables.go.
- Generate SQL migrations for Go using table structs
-
A struct mapper, query builder and migration tool for Go.
Finally it comes with a migration tool, sqddl, that supports a code-first workflow where you define table structs in Go and the tool figures out the DDL statements required to reach that destination schema from a source schema. It's basically GORM's automigrate, except instead of passing in table structs one-by-one for reflection it parses all table structs on the level of Go source files so adding a new table is as simple as defining a new table struct in your Go code. You can view a runnable playground example here: https://go.dev/play/p/S0jptJmsn70 (N.B. you might need to hit run a second time if it times out).
ent
Posts with mentions or reviews of ent.
We have used some of these posts to build our list of alternatives
and similar projects. The last one was on 2024-03-21.
-
Concurrency Control in Go with Ent ORM and MySQL
In this article, we'll delve into the world of concurrency control in Go, specifically focusing on the optimistic locking approach. We'll explore its implementation using Ent ORM to illustrate how to manage data consistency when multiple users interact with the same resource. Keep in mind that this example serves as a simplified illustration, and real-world booking systems involve a many of additional complexities. However, the core concepts presented here provide a solid foundation for understanding optimistic locking in Go applications. Feel free to explore the complete source code in my GitHub repository for a more in-depth look at the implementation.
-
Go ORMs Compared
ent is a fairly recent ORM that uses a code-first approach where you define your schema in Go code. Ent is popular thanks to its ability to handle complex data models and relationships elegantly. It's statically typed, which can help catch errors at compile time. However, the learning curve might be steeper compared to more straightforward ORMs like GORM. It's a good fit for applications where complex data models and type safety are priorities.
-
Stop using entgo...please
If you found this article, than you are probably similar to how I was a few months ago. I started a project in Go that required a SQL backend and I wanted to use any tool that would help me build this backend quickly. I stumbled upon entgo (an ORM for Go) and decided to give it a try.
- Pocketbase: Open-source back end in 1 file
-
Why Golang instead of Rust to develop the Krater desktop app
The ent orm for golang actually does some useful work for you. https://github.com/ent/ent
- Open-sourcing SQX, a way to build flexible database models in Go
-
Learning Go for Backend/Fullstack development?
Backend Database interaction with entgo
- Ent ORM for Golang
- My Issue With ORMs
-
What project architecture/structure would you recommend?
You can use entgo.io for ORM stuff, it also has entgql extension that integrated with GQLGen. See more at the document: https://entgo.io/docs/tutorial-todo-gql
What are some alternatives?
When comparing sqddl and ent you can also consider the following projects:
sq - sq is a type-safe data mapper and query builder for Go.
GORM - The fantastic ORM library for Golang, aims to be developer friendly
go_sql_benchmarks
SQLBoiler - Generate a Go ORM tailored to your database schema.
kago - KaGo
sqlc - Generate type-safe code from SQL
goqu - SQL builder and query library for golang
sqlx - general purpose extensions to golang's database/sql
dolt - Dolt – Git for Data
Xorm
go-pg - Golang ORM with focus on PostgreSQL features and performance
prisma-client-go - Prisma Client Go is an auto-generated and fully type-safe database client