代码拉取完成,页面将自动刷新
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
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。