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-06-24 07:43:28 +00:00
I really need a create table SQL builder, and I can't find one. So, like everything else, I made one. Heavily inspired by [Squirrel ](https://github.com/Masterminds/squirrel ) and [Knex ](https://knexjs.org/ ).
Oh, and of course, heavily inspired by Bob the Builder.
## Usage
It's not ready for production (yet). But, the API is probably close to how you'd do things on Squirrel.
```go
import "github.com/aldy505/bob"
func main() {
sql, _, err := bob.CreateTable("users").
Columns("id", "email", "name", "password", "date").
Types("varchar(36)", "varchar(255)", "varchar(255)", "text", "date").
Primary("id").
Unique("email")
2021-06-26 02:57:08 +00:00
ToSQL()
2021-06-24 07:43:28 +00:00
if err != nil {
log.Fatal(err)
}
// process SQL with whatever you like it
}
```