6 Star 28 Fork 7

艾润物联/go-sqlbuilder

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
update.go 1.91 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 UpdateBuilder struct {
table string
columnValues []string
forceUpdate bool
}
func Update(table string) *UpdateBuilder {
return (&UpdateBuilder{
columnValues: make([]string, 0),
}).Table(table)
}
func (slf *UpdateBuilder) Table(table string) *UpdateBuilder {
slf.table = table
return slf
}
func (slf *UpdateBuilder) Columns(columns ...string) *UpdateBuilder {
if len(columns) == 0 {
panic("Columns is required for update")
}
slf.columnValues = Map(columns, func(column string) string {
return EscapeName(column) + "=?"
})
return slf
}
func (slf *UpdateBuilder) ColumnAndValue(column string, value interface{}) *UpdateBuilder {
slf.columnValues = append(slf.columnValues, func() string {
return EscapeName(column) + "=" + EscapeValue(value)
}())
return slf
}
func (slf *UpdateBuilder) compile() *bytes.Buffer {
if "" == slf.table {
panic("Table name not found, you should call 'Table(table)' method to set it")
}
buf := new(bytes.Buffer)
buf.WriteString("UPDATE ")
buf.WriteString(EscapeName(slf.table))
buf.WriteString(" SET ")
// 此处Columns不需要转义处理
buf.WriteString(strings.Join(slf.columnValues, SQLComma))
return buf
}
func (slf *UpdateBuilder) YesYesYesForceUpdate() *UpdateBuilder {
slf.forceUpdate = true
return slf
}
func (slf *UpdateBuilder) Where(conditions SQLStatement) *WhereBuilder {
return newWhere(slf, conditions)
}
func (slf *UpdateBuilder) Compile() string {
return slf.compile().String()
}
func (slf *UpdateBuilder) GetSQL() string {
sqlTxt := endOfSQL(slf.compile())
if slf.forceUpdate {
return sqlTxt
} else {
panic("Warning for FULL-UPDATE, you should call 'YesYesYesForceUpdate(bool)' to ensure. SQLText: " + sqlTxt)
}
}
func (slf *UpdateBuilder) 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

搜索帮助