代码拉取完成,页面将自动刷新
package gsb
import (
"bytes"
)
//
// Author: 陈永佳 chenyongjia@parkingwang.com, yoojiachen@gmail.com
//
type InsertBuilder struct {
table string
columns []string
values []interface{}
}
func Insert(table string) *InsertBuilder {
return &InsertBuilder{
table: table,
columns: make([]string, 0),
values: make([]interface{}, 0),
}
}
func (slf *InsertBuilder) Table(table string) *InsertBuilder {
slf.table = table
return slf
}
func (slf *InsertBuilder) Columns(columns ...string) *InsertBuilder {
for _, col := range columns {
slf.columns = append(slf.columns, col)
slf.values = append(slf.values, SQLPlaceHolder)
}
return slf
}
func (slf *InsertBuilder) Values(values ...interface{}) *InsertBuilder {
// check columns and values
if len(slf.columns) != len(slf.values) {
panic("length of columns and values NOT MATCH")
}
for i, newVal := range values {
slf.values[i] = newVal
}
return slf
}
func (slf *InsertBuilder) compile() *bytes.Buffer {
if "" == slf.table {
panic("table not found, you should call 'Table(table)' method to set it")
}
buf := new(bytes.Buffer)
buf.WriteString("INSERT INTO ")
buf.WriteString(EscapeName(slf.table))
buf.WriteByte('(')
buf.WriteString(joinNames(slf.columns))
buf.WriteByte(')')
buf.WriteString(" VALUES ")
buf.WriteByte('(')
buf.WriteString(joinValues(slf.values))
buf.WriteByte(')')
return buf
}
func (slf *InsertBuilder) GetSQL() string {
return endOfSQL(slf.compile())
}
func (slf *InsertBuilder) Execute(prepare SQLPrepare) *Executor {
return newExecute(slf.GetSQL(), prepare)
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。