Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/stephenafamo/bob
SQL query builder and ORM/Factory generator for Go with support for PostgreSQL, MySQL and SQLite
https://github.com/stephenafamo/bob
database golang hacktoberfest mysql orm postgres postgresql prisma psql query-builder sql sqlite sqlite3
Last synced: 4 days ago
JSON representation
SQL query builder and ORM/Factory generator for Go with support for PostgreSQL, MySQL and SQLite
- Host: GitHub
- URL: https://github.com/stephenafamo/bob
- Owner: stephenafamo
- License: mit
- Created: 2022-04-20T23:10:57.000Z (almost 3 years ago)
- Default Branch: main
- Last Pushed: 2024-12-26T23:12:29.000Z (25 days ago)
- Last Synced: 2025-01-10T04:04:34.678Z (11 days ago)
- Topics: database, golang, hacktoberfest, mysql, orm, postgres, postgresql, prisma, psql, query-builder, sql, sqlite, sqlite3
- Language: Go
- Homepage: https://bob.stephenafamo.com
- Size: 2.3 MB
- Stars: 851
- Watchers: 9
- Forks: 47
- Open Issues: 22
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
Awesome Lists containing this project
- awesome-go - bob - SQL query builder and ORM/Factory generator for Go. Successor of SQLBoiler. (ORM / HTTP Clients)
README
# Bob: Go SQL Access Toolkit
[![Test Status](https://github.com/stephenafamo/bob/actions/workflows/test.yml/badge.svg)](https://github.com/stephenafamo/bob/actions/workflows/test.yml) ![GitHub go.mod Go version](https://img.shields.io/github/go-mod/go-version/stephenafamo/bob) [![Go Reference](https://pkg.go.dev/badge/github.com/stephenafamo/bob.svg)](https://pkg.go.dev/github.com/stephenafamo/bob) [![Go Report Card](https://goreportcard.com/badge/github.com/stephenafamo/bob)](https://goreportcard.com/report/github.com/stephenafamo/bob) ![GitHub tag (latest SemVer)](https://img.shields.io/github/v/tag/stephenafamo/bob) [![Coverage Status](https://coveralls.io/repos/github/stephenafamo/bob/badge.svg)](https://coveralls.io/github/stephenafamo/bob)
## Links
- [Documentation][docs]
- [Reference][reference]## About
Bob is a set of Go packages and tools to work with SQL databases.
Bob's philosophy centres around the following:
1. **Correctness**: Things should work correctly. Follow specifications as closely as possible.
2. **Convenience** (not magic): Bob provides convenient ways to perform actions, it does not add unexplainable magic, or needless abstraction.
3. **Cooperation**: Bob should work well with other tools and packages as much as possible, especially the standard library.**Bob** can be progressively adopted from raw SQL query strings, to fully typed queries with models and factories generated for your database.
## Components of Bob
**Bob** consists of several components that build on each other for the full experience.
1. Query Builder
1. SQL Executor for convenient scanning of results
1. Models for convenient database queries
1. Code generation of Models and Factories from your database schemaCheck out [the documentation][docs] for more information.
## Support
| | Queries | Models | ORM Gen | Factory Gen |
| ------------- | ------- | ------ | ------- | ----------- |
| Postgres | ✅ | ✅ | ✅ | ✅ |
| MySQL/MariaDB | ✅ | ✅ | ✅ | ✅ |
| SQLite | ✅ | ✅ | ✅ | ✅ |## Comparisons
1. [Bob vs GORM](https://bob.stephenafamo.com/vs/gorm)
1. [Bob vs Ent](https://bob.stephenafamo.com/vs/ent)
1. [Bob vs SQLBoiler](https://bob.stephenafamo.com/vs/sqlboiler)
1. [Bob vs Jet](https://bob.stephenafamo.com/vs/jet)[docs]: https://bob.stephenafamo.com/docs
[reference]: https://pkg.go.dev/github.com/stephenafamo/bob## Contributing
Thanks to all the people who have contributed to Bob!
[![contributors](https://contributors-img.web.app/image?repo=stephenafamo/bob)](https://github.com/stephenafamo/bob/graphs/contributors)