6 Star 28 Fork 7

艾润物联/go-sqlbuilder

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
condition.go 3.85 KB
一键复制 编辑 原始数据 按行查看 历史
Yoojia Chen 提交于 2018-05-17 21:33 +08:00 . Rename package from sqlx to gsb
package gsb
import (
"bytes"
)
//
// Author: 陈永佳 chenyongjia@parkingwang.com, yoojiachen@gmail.com
//
type Condition struct {
buffer *bytes.Buffer
}
func newCondition() *Condition {
return &Condition{
buffer: new(bytes.Buffer),
}
}
func (slf *Condition) And() *Condition {
slf.buffer.WriteString(" AND ")
return slf
}
func (slf *Condition) Or() *Condition {
slf.buffer.WriteString(" OR ")
return slf
}
func (slf *Condition) Compile() string {
return slf.buffer.String()
}
//// Conditions
func Equal(column string) *Condition {
return newCondition().Equal(column)
}
func (slf *Condition) Equal(column string) *Condition {
return slf.EqualTo(column, SQLPlaceHolder)
}
func EqualTo(column string, value interface{}) *Condition {
return newCondition().EqualTo(column, value)
}
func (slf *Condition) EqualTo(column string, value interface{}) *Condition {
slf.buffer.WriteString(op(column, " = ", value))
return slf
}
func NotEqual(column string) *Condition {
return newCondition().NotEqual(column)
}
func (slf *Condition) NotEqual(column string) *Condition {
return slf.NotEqualTo(column, SQLPlaceHolder)
}
func NotEqualTo(column string, value interface{}) *Condition {
return newCondition().NotEqualTo(column, value)
}
func (slf *Condition) NotEqualTo(column string, value interface{}) *Condition {
slf.buffer.WriteString(op(column, " <> ", value))
return slf
}
func GreaterThen(column string) *Condition {
return newCondition().GreaterThen(column)
}
func (slf *Condition) GreaterThen(column string) *Condition {
return slf.GreaterThenTo(column, SQLPlaceHolder)
}
func GreaterThenTo(column string, value interface{}) *Condition {
return newCondition().GreaterThenTo(column, value)
}
func (slf *Condition) GreaterThenTo(column string, value interface{}) *Condition {
slf.buffer.WriteString(op(column, " > ", value))
return slf
}
func GreaterEqualThen(column string) *Condition {
return newCondition().GreaterEqualThen(column)
}
func (slf *Condition) GreaterEqualThen(column string) *Condition {
return slf.GreaterEqualThenTo(column, SQLPlaceHolder)
}
func GreaterEqualThenTo(column string, value interface{}) *Condition {
return newCondition().GreaterEqualThenTo(column, value)
}
func (slf *Condition) GreaterEqualThenTo(column string, value interface{}) *Condition {
slf.buffer.WriteString(op(column, " >= ", value))
return slf
}
func LessThen(column string) *Condition {
return newCondition().LessThen(column)
}
func (slf *Condition) LessThen(column string) *Condition {
return slf.LessEqualThenTo(column, SQLPlaceHolder)
}
func LessThenTo(column string, value interface{}) *Condition {
return newCondition().LessThenTo(column, value)
}
func (slf *Condition) LessThenTo(column string, value interface{}) *Condition {
slf.buffer.WriteString(op(column, " < ", value))
return slf
}
func LessEqualThen(column string) *Condition {
return newCondition().LessEqualThen(column)
}
func (slf *Condition) LessEqualThen(column string) *Condition {
return slf.LessEqualThenTo(column, SQLPlaceHolder)
}
func LessEqualThenTo(column string, value interface{}) *Condition {
return newCondition().LessEqualThenTo(column, value)
}
func (slf *Condition) LessEqualThenTo(column string, value interface{}) *Condition {
slf.buffer.WriteString(op(column, " <= ", value))
return slf
}
//
func (slf *Condition) Like(column string, pattern string) *Condition {
slf.buffer.WriteString(op(column, " LIKE ", pattern))
return slf
}
func (slf *Condition) Between(column string, start interface{}, end interface{}) *Condition {
slf.buffer.WriteString(opv(column, " BETWEEN ", EscapeValue(start)+" AND "+EscapeValue(end)))
return slf
}
func (slf *Condition) In(column string, items ...interface{}) *Condition {
slf.buffer.WriteString(opv(column, " IN ", brackets(joinValues(items))))
return slf
}
func opv(name string, op string, value string) string {
return EscapeName(name) + op + value
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/iRainIoT/go-sqlbuilder.git
git@gitee.com:iRainIoT/go-sqlbuilder.git
iRainIoT
go-sqlbuilder
go-sqlbuilder
37658dd0e549

搜索帮助