6 Star 28 Fork 7

艾润物联/go-sqlbuilder

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
create_index.go 1.68 KB
一键复制 编辑 原始数据 按行查看 历史
Yoojia Chen 提交于 2018-05-17 21:33 +08:00 . Rename package from sqlx to gsb
package gsb
import (
"bytes"
"strings"
)
//
// Author: 陈永佳 chenyongjia@parkingwang.com, yoojiachen@gmail.com
//
type CreateIndexBuilder struct {
table string
name string
columns []string
unique bool
}
func CreateIndex(indexName string) *CreateIndexBuilder {
return &CreateIndexBuilder{
name: indexName,
columns: make([]string, 0),
}
}
func (slf *CreateIndexBuilder) Unique() *CreateIndexBuilder {
slf.unique = true
return slf
}
func (slf *CreateIndexBuilder) OnTable(table string) *CreateIndexBuilder {
slf.table = table
return slf
}
func (slf *CreateIndexBuilder) Column(name string, desc bool) *CreateIndexBuilder {
var column string
if desc {
column = EscapeName(name) + SQLSpace + "DESC"
} else {
column = EscapeName(column)
}
slf.columns = append(slf.columns, column)
return slf
}
func (slf *CreateIndexBuilder) Columns(columns ...string) *CreateIndexBuilder {
slf.columns = append(slf.columns, Map(columns, EscapeName)...)
return slf
}
func (slf *CreateIndexBuilder) build() *bytes.Buffer {
if "" == slf.table {
panic("table not found, you should call 'Table(table)' method to set it")
}
buf := new(bytes.Buffer)
buf.WriteString("CREATE ")
if slf.unique {
buf.WriteString("UNIQUE ")
}
buf.WriteString("INDEX ")
buf.WriteString(EscapeName(slf.name))
buf.WriteString(" ON ")
buf.WriteString(EscapeName(slf.table))
buf.WriteByte('(')
// 在输入时已经转义
buf.WriteString(strings.Join(slf.columns, SQLComma))
buf.WriteByte(')')
return buf
}
func (slf *CreateIndexBuilder) GetSQL() string {
return endOfSQL(slf.build())
}
func (slf *CreateIndexBuilder) Execute(prepare SQLPrepare) *Executor {
return newExecute(slf.GetSQL(), prepare)
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/iRainIoT/go-sqlbuilder.git
git@gitee.com:iRainIoT/go-sqlbuilder.git
iRainIoT
go-sqlbuilder
go-sqlbuilder
37658dd0e549

搜索帮助