2021-06-24 07:43:28 +00:00
# Bob - SQL Query Builder
2021-06-25 07:32:12 +00:00
[![Go Reference ](https://pkg.go.dev/badge/github.com/aldy505/bob.svg )](https://pkg.go.dev/github.com/aldy505/bob) [![Go Report Card ](https://goreportcard.com/badge/github.com/aldy505/bob )](https://goreportcard.com/report/github.com/aldy505/bob) ![GitHub ](https://img.shields.io/github/license/aldy505/bob ) [![CodeFactor ](https://www.codefactor.io/repository/github/aldy505/bob/badge )](https://www.codefactor.io/repository/github/aldy505/bob) [![codecov ](https://codecov.io/gh/aldy505/bob/branch/master/graph/badge.svg?token=Noeexg5xEJ )](https://codecov.io/gh/aldy505/bob) [![Codacy Badge ](https://app.codacy.com/project/badge/Grade/9b78970127c74c1a923533e05f65848d )](https://www.codacy.com/gh/aldy505/bob/dashboard?utm_source=github.com& utm_medium=referral& utm_content=aldy505/bob& utm_campaign=Badge_Grade) [![Build test ](https://github.com/aldy505/bob/actions/workflows/build.yml/badge.svg )](https://github.com/aldy505/bob/actions/workflows/build.yml) [![Test and coverage ](https://github.com/aldy505/bob/actions/workflows/coverage.yml/badge.svg )](https://github.com/aldy505/bob/actions/workflows/coverage.yml)
2021-07-21 09:00:05 +00:00
Think of this as an extension of [Squirrel ](https://github.com/Masterminds/squirrel ) with functionability like [Knex ](https://knexjs.org/ ). I still use Squirrel for other types of queries (insert, select, and all that), but I needed some SQL builder for create table and some other stuffs.
2021-06-24 07:43:28 +00:00
2021-07-21 09:00:05 +00:00
Oh, and of course, heavily inspired by [Bob the Builder ](https://en.wikipedia.org/wiki/Bob_the_Builder ).
2021-06-24 07:43:28 +00:00
2021-07-09 06:47:26 +00:00
```go
import "github.com/aldy505/bob"
```
2021-06-24 07:43:28 +00:00
## Usage
2021-06-30 15:58:25 +00:00
It's not ready for production yet. But, the API is probably close to how you'd do things on Squirrel. This is an example for using with pgx.
2021-06-24 07:43:28 +00:00
```go
2021-06-30 15:58:25 +00:00
import (
"context"
"log"
"strings"
"github.com/aldy505/bob"
"github.com/jackc/pgx/v4"
)
2021-06-24 07:43:28 +00:00
func main() {
2021-06-30 15:58:25 +00:00
db := pgx.Connect()
// Check if a table is exists
2021-07-09 06:41:34 +00:00
sql, args, err = bob.HasTable("users").PlaceholderFormat(bob.Dollar).ToSql()
2021-06-30 16:01:13 +00:00
if err != nil {
log.Fatal(err)
}
2021-06-30 15:58:25 +00:00
var hasTableUsers bool
err = db.QueryRow(context.Background(), sql, args...).Scan(& hasTableUsers)
2021-06-24 07:43:28 +00:00
if err != nil {
2021-07-21 09:00:05 +00:00
if err == bob.ErrEmptyTablePg {
2021-06-30 16:01:13 +00:00
hasTableUsers = false
} else {
log.Fatal(err)
}
2021-06-24 07:43:28 +00:00
}
2021-06-30 15:58:25 +00:00
if !hasTableUsers {
// Create "users" table
// Note that this will return multiple query in a single string.
2021-07-21 09:00:05 +00:00
sql, _, err := bob.
CreateTable("users").
IntegerColumn("id", "PRIMARY KEY", "SERIAL").
StringColumn("name", "NOT NULL").
TextColumn("password", "NOT NULL").
DateColumn("created_at").
2021-07-09 06:41:34 +00:00
ToSql()
2021-06-30 15:58:25 +00:00
if err != nil {
log.Fatal(err)
}
2021-07-21 09:00:05 +00:00
_, err = db.Query(context.Background(), splitQuery[i])
if err != nil {
log.Fatal(err)
2021-06-30 15:58:25 +00:00
}
2021-07-09 06:47:26 +00:00
// Create another table, this time with CREATE TABLE IF NOT EXISTS
2021-07-21 09:00:05 +00:00
sql, _, err := bob.
CreateTableIfNotExists("inventory").
UUIDColumn("id", "PRIMARY KEY").
IntegerColumn("userID", "FOREIGN KEY REFERENCES users(id)").
JSONColumn("items").
IntegerColumn("quantity").
2021-07-09 06:47:26 +00:00
ToSql()
if err != nil {
log.Fatal(err)
}
2021-07-21 09:00:05 +00:00
_, err = db.Query(context.Background(), inventoryQuery[i])
if err != nil {
log.Fatal(err)
2021-07-09 06:47:26 +00:00
}
2021-06-30 15:58:25 +00:00
}
2021-06-24 07:43:28 +00:00
}
2021-07-09 06:47:26 +00:00
```
2021-07-21 09:00:05 +00:00
## Features
* `bob.CreateTable(tableName)` - Basic SQL create table
* `bob.CreateTableIfNotExists(tableName)` - Create table if not exists
* `bob.HasTable(tableName)` - Checks if column exists (return error if false, check example above for error handling)
* `bob.HasColumn(columnName)` - Check if a column exists on current table
### TODO
Meaning these are some ideas for the future development of Bob.
* `bob.DropTable(tableName)` - Drop a table (`drop table "users"`)
* `bob.DropTableIfExists(tableName)` - Drop a table if exists (`drop table if exists "users"`)
* `bob.RenameTable(tableName)` - Rename a table (`rename table "users" to "old_users"`)
* `bob.Truncate(tableName)` - Truncate a table (`truncate "users"`)
* `bob.Upsert(tableName)` - UPSERT function (`insert into "users" ("name", "email") values (?, ?) on duplicate key update email = ?`)
* `bob.ExecWith()` - Just like Squirrel's [ExecWith ](https://pkg.go.dev/github.com/Masterminds/squirrel?utm_source=godoc#ExecWith )
* `bob.Count(tableName, columnName)` - Count query (`select count("active") from "users"`)
2021-07-09 06:47:26 +00:00
## Contributing
Contributions are always welcome! As long as you add a test for your changes.
## License
Bob is licensed under [MIT license ](./LICENSE )