2021-06-24 07:43:28 +00:00
|
|
|
package bob
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
|
|
|
"errors"
|
|
|
|
"strings"
|
|
|
|
|
|
|
|
"github.com/aldy505/bob/util"
|
|
|
|
"github.com/lann/builder"
|
|
|
|
)
|
|
|
|
|
|
|
|
type CreateBuilder builder.Builder
|
|
|
|
|
|
|
|
type createData struct {
|
2021-07-09 06:39:30 +00:00
|
|
|
TableName string
|
|
|
|
IfNotExists bool
|
|
|
|
Schema string
|
|
|
|
Columns []string
|
|
|
|
Types []string
|
|
|
|
Primary string
|
|
|
|
Unique string
|
|
|
|
NotNull []string
|
2021-06-24 07:43:28 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
builder.Register(CreateBuilder{}, createData{})
|
|
|
|
}
|
|
|
|
|
2021-06-26 02:57:08 +00:00
|
|
|
// Name sets the table name
|
2021-06-24 07:43:28 +00:00
|
|
|
func (b CreateBuilder) Name(name string) CreateBuilder {
|
|
|
|
return builder.Set(b, "TableName", name).(CreateBuilder)
|
|
|
|
}
|
|
|
|
|
2021-07-09 06:39:30 +00:00
|
|
|
// IfNotExists adds IF NOT EXISTS to the query
|
|
|
|
func (b CreateBuilder) IfNotExists() CreateBuilder {
|
|
|
|
return builder.Set(b, "IfNotExists", true).(CreateBuilder)
|
|
|
|
}
|
|
|
|
|
2021-06-26 02:57:08 +00:00
|
|
|
// WithSchema specifies the schema to be used when using the schema-building commands.
|
2021-06-24 07:43:28 +00:00
|
|
|
func (b CreateBuilder) WithSchema(name string) CreateBuilder {
|
|
|
|
return builder.Set(b, "Schema", name).(CreateBuilder)
|
|
|
|
}
|
|
|
|
|
2021-06-26 02:57:08 +00:00
|
|
|
// Columns sets the column names
|
2021-06-24 07:43:28 +00:00
|
|
|
func (b CreateBuilder) Columns(cols ...string) CreateBuilder {
|
|
|
|
return builder.Set(b, "Columns", cols).(CreateBuilder)
|
|
|
|
}
|
|
|
|
|
2021-06-26 02:57:08 +00:00
|
|
|
// Types set a type for certain column
|
2021-06-24 07:43:28 +00:00
|
|
|
func (b CreateBuilder) Types(types ...string) CreateBuilder {
|
|
|
|
return builder.Set(b, "Types", types).(CreateBuilder)
|
|
|
|
}
|
|
|
|
|
2021-06-26 02:57:08 +00:00
|
|
|
// Primary will set that column as the primary key for a table.
|
2021-06-24 07:43:28 +00:00
|
|
|
func (b CreateBuilder) Primary(column string) CreateBuilder {
|
|
|
|
return builder.Set(b, "Primary", column).(CreateBuilder)
|
|
|
|
}
|
|
|
|
|
2021-06-26 02:57:08 +00:00
|
|
|
// Unique adds an unique index to a table over the given columns.
|
2021-06-24 07:43:28 +00:00
|
|
|
func (b CreateBuilder) Unique(column string) CreateBuilder {
|
|
|
|
return builder.Set(b, "Unique", column).(CreateBuilder)
|
|
|
|
}
|
|
|
|
|
2021-07-09 06:41:34 +00:00
|
|
|
// ToSql returns 3 variables filled out with the correct values based on bindings, etc.
|
|
|
|
func (b CreateBuilder) ToSql() (string, []interface{}, error) {
|
2021-06-24 07:43:28 +00:00
|
|
|
data := builder.GetStruct(b).(createData)
|
2021-07-09 06:41:34 +00:00
|
|
|
return data.ToSql()
|
2021-06-24 07:43:28 +00:00
|
|
|
}
|
|
|
|
|
2021-07-09 06:41:34 +00:00
|
|
|
// ToSql returns 3 variables filled out with the correct values based on bindings, etc.
|
|
|
|
func (d *createData) ToSql() (sqlStr string, args []interface{}, err error) {
|
2021-06-24 08:15:36 +00:00
|
|
|
if len(d.TableName) == 0 || d.TableName == "" {
|
2021-06-24 07:43:28 +00:00
|
|
|
err = errors.New("create statements must specify a table")
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if (len(d.Columns) != len(d.Types)) && len(d.Columns) > 0 {
|
|
|
|
err = errors.New("columns and types should have equal length")
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
sql := &bytes.Buffer{}
|
|
|
|
|
|
|
|
sql.WriteString("CREATE TABLE ")
|
|
|
|
|
2021-07-09 06:39:30 +00:00
|
|
|
if d.IfNotExists {
|
|
|
|
sql.WriteString("IF NOT EXISTS ")
|
|
|
|
}
|
|
|
|
|
2021-06-24 07:43:28 +00:00
|
|
|
if d.Schema != "" {
|
2021-06-30 15:57:32 +00:00
|
|
|
sql.WriteString("\"" + d.Schema + "\".")
|
2021-06-24 07:43:28 +00:00
|
|
|
}
|
|
|
|
|
2021-06-30 15:57:32 +00:00
|
|
|
sql.WriteString("\"" + d.TableName + "\"")
|
2021-06-24 07:43:28 +00:00
|
|
|
sql.WriteString(" ")
|
|
|
|
|
|
|
|
var columnTypes []string
|
|
|
|
for i := 0; i < len(d.Columns); i++ {
|
2021-06-30 15:57:32 +00:00
|
|
|
columnTypes = append(columnTypes, "\""+d.Columns[i]+"\" "+d.Types[i])
|
2021-06-24 07:43:28 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
sql.WriteString("(")
|
|
|
|
sql.WriteString(strings.Join(columnTypes, ", "))
|
|
|
|
sql.WriteString(");")
|
|
|
|
|
2021-06-24 08:15:36 +00:00
|
|
|
if d.Primary != "" {
|
|
|
|
if !util.IsIn(d.Columns, d.Primary) {
|
|
|
|
err = errors.New("supplied primary column name doesn't exists on columns")
|
|
|
|
return
|
|
|
|
}
|
2021-06-24 07:43:28 +00:00
|
|
|
sql.WriteString(" ")
|
2021-06-30 15:57:32 +00:00
|
|
|
sql.WriteString("ALTER TABLE \"" + d.TableName + "\" ADD PRIMARY KEY (\"" + d.Primary + "\");")
|
2021-06-24 07:43:28 +00:00
|
|
|
}
|
|
|
|
|
2021-06-24 08:15:36 +00:00
|
|
|
if d.Unique != "" {
|
|
|
|
if !util.IsIn(d.Columns, d.Unique) {
|
|
|
|
err = errors.New("supplied unique column name doesn't exists on columns")
|
|
|
|
return
|
|
|
|
}
|
2021-06-24 07:43:28 +00:00
|
|
|
sql.WriteString(" ")
|
2021-06-30 15:57:32 +00:00
|
|
|
sql.WriteString("ALTER TABLE \"" + d.TableName + "\" ADD UNIQUE (\"" + d.Unique + "\");")
|
2021-06-24 07:43:28 +00:00
|
|
|
}
|
|
|
|
sqlStr = sql.String()
|
|
|
|
return
|
|
|
|
}
|