bob/drop.go

72 lines
1.5 KiB
Go
Raw Permalink Normal View History

2021-07-24 18:35:12 +00:00
package bob
import (
"errors"
2021-11-05 05:06:47 +00:00
"strings"
2021-07-24 18:35:12 +00:00
"github.com/lann/builder"
)
type DropBuilder builder.Builder
type dropData struct {
TableName string
2021-07-31 04:48:40 +00:00
IfExists bool
2021-11-05 05:06:47 +00:00
Cascade bool
Restrict bool
2021-07-24 18:35:12 +00:00
}
func init() {
builder.Register(DropBuilder{}, dropData{})
}
// DropTable sets which table to be dropped
2021-07-31 04:17:48 +00:00
func (b DropBuilder) dropTable(name string) DropBuilder {
2021-07-24 18:35:12 +00:00
return builder.Set(b, "TableName", name).(DropBuilder)
}
2021-07-31 04:17:48 +00:00
func (b DropBuilder) ifExists() DropBuilder {
2021-07-24 18:35:12 +00:00
return builder.Set(b, "IfExists", true).(DropBuilder)
}
2021-11-05 05:06:47 +00:00
func (b DropBuilder) Cascade() DropBuilder {
return builder.Set(b, "Cascade", true).(DropBuilder)
}
func (b DropBuilder) Restrict() DropBuilder {
return builder.Set(b, "Restrict", true).(DropBuilder)
}
2021-07-24 18:35:12 +00:00
// ToSql returns 3 variables filled out with the correct values based on bindings, etc.
func (b DropBuilder) ToSql() (string, []interface{}, error) {
data := builder.GetStruct(b).(dropData)
return data.ToSql()
}
// ToSql returns 3 variables filled out with the correct values based on bindings, etc.
func (d *dropData) ToSql() (sqlStr string, args []interface{}, err error) {
if len(d.TableName) == 0 || d.TableName == "" {
err = errors.New("drop statement must specify a table")
}
2021-11-05 05:06:47 +00:00
var sql strings.Builder
2021-07-24 18:35:12 +00:00
sql.WriteString("DROP TABLE ")
if d.IfExists {
sql.WriteString("IF EXISTS ")
}
2021-07-31 04:48:40 +00:00
2021-11-05 05:06:47 +00:00
sql.WriteString("\"" + d.TableName + "\"")
if d.Cascade {
sql.WriteString(" CASCADE")
} else if d.Restrict {
sql.WriteString(" RESTRICT")
}
sql.WriteString(";")
2021-07-24 18:35:12 +00:00
sqlStr = sql.String()
return
2021-07-31 04:48:40 +00:00
}