mirror of https://github.com/writeas/writefreely
A focused writing and publishing space.
https://write.with.parts
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
76 lines
2.3 KiB
76 lines
2.3 KiB
package db
|
|
|
|
import "fmt"
|
|
|
|
type DialectType int
|
|
|
|
const (
|
|
DialectSQLite DialectType = iota
|
|
DialectMySQL DialectType = iota
|
|
)
|
|
|
|
func (d DialectType) Column(name string, t ColumnType, size OptionalInt) *Column {
|
|
switch d {
|
|
case DialectSQLite:
|
|
return &Column{Dialect: DialectSQLite, Name: name, Type: t, Size: size}
|
|
case DialectMySQL:
|
|
return &Column{Dialect: DialectMySQL, Name: name, Type: t, Size: size}
|
|
default:
|
|
panic(fmt.Sprintf("unexpected dialect: %d", d))
|
|
}
|
|
}
|
|
|
|
func (d DialectType) Table(name string) *CreateTableSqlBuilder {
|
|
switch d {
|
|
case DialectSQLite:
|
|
return &CreateTableSqlBuilder{Dialect: DialectSQLite, Name: name}
|
|
case DialectMySQL:
|
|
return &CreateTableSqlBuilder{Dialect: DialectMySQL, Name: name}
|
|
default:
|
|
panic(fmt.Sprintf("unexpected dialect: %d", d))
|
|
}
|
|
}
|
|
|
|
func (d DialectType) AlterTable(name string) *AlterTableSqlBuilder {
|
|