1 Star 0 Fork 0

h79/goutils

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
orderby.go 1.21 KB
一键复制 编辑 原始数据 按行查看 历史
huqiuyun 提交于 2022-12-29 12:51 . sql column
package wrapper
import (
"fmt"
"strings"
)
const (
kDesc = "DESC"
kAsc = "ASC"
maxColumns = 6
)
// OrderBy 排序(降序(大=>小)desc, 升序(小=>大)asc
// example: "orderBy:[{"col:"create_at","desc":true}, {"col":"id","desc":false}]
//
// "orderBy:[{"col:"create_at,id","desc":true}]
type OrderBy []*Column
func (ob OrderBy) Check(filters []FField) {
length := len(ob)
if length > maxColumns { //防止多
length = maxColumns
}
cols := ob[:length]
for i := range cols {
cols[i].Check(filters)
}
}
func (ob OrderBy) sqlCol(col *Column, convert ColumnConvert) string {
if len(col.Column) > 0 && col.Desc {
return fmt.Sprintf("%s %s", convert(col.Column), kDesc)
}
return convert(col.Column)
}
func (ob OrderBy) Sql(full bool, convert ColumnConvert) string {
if convert == nil {
convert = defColumnConvert
}
count := 0
builder := strings.Builder{}
for i := range ob {
if count >= maxColumns {
//后面不要接入
break
}
c := ob.sqlCol(ob[i], convert)
if len(c) == 0 {
continue
}
if count == 0 && full {
builder.WriteString(" ORDER BY ")
}
if count > 0 {
builder.WriteByte(',')
}
builder.WriteString(c)
count++
}
return builder.String()
}
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/h79/goutils.git
git@gitee.com:h79/goutils.git
h79
goutils
goutils
v1.3.50

搜索帮助