1 Star 1 Fork 0

bigbase / pg

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
util.go 2.88 KB
一键复制 编辑 原始数据 按行查看 历史
Vladimir Mihailenco 提交于 2017-06-11 13:24 . Support bulk updates
package orm
import (
"reflect"
"github.com/go-pg/pg/types"
)
func indirectType(t reflect.Type) reflect.Type {
if t.Kind() == reflect.Ptr {
t = t.Elem()
}
return t
}
func sliceElemType(v reflect.Value) reflect.Type {
elemType := v.Type().Elem()
if elemType.Kind() == reflect.Interface && v.Len() > 0 {
return reflect.Indirect(v.Index(0).Elem()).Type()
} else {
return indirectType(elemType)
}
}
func typeByIndex(t reflect.Type, index []int) reflect.Type {
for _, x := range index {
switch t.Kind() {
case reflect.Ptr:
t = t.Elem()
case reflect.Slice:
t = indirectType(t.Elem())
}
t = t.Field(x).Type
}
return indirectType(t)
}
func fieldByIndex(v reflect.Value, index []int) reflect.Value {
for i, x := range index {
if i > 0 {
v = indirectNew(v)
}
v = v.Field(x)
}
return v
}
func indirectNew(v reflect.Value) reflect.Value {
if v.Kind() == reflect.Ptr {
if v.IsNil() {
v.Set(reflect.New(v.Type().Elem()))
}
v = v.Elem()
}
return v
}
func columns(b []byte, table types.Q, prefix string, fields []*Field) []byte {
for i, f := range fields {
if i > 0 {
b = append(b, ", "...)
}
if len(table) > 0 {
b = append(b, table...)
b = append(b, '.')
}
b = types.AppendField(b, prefix+f.SQLName, 1)
}
return b
}
func walk(v reflect.Value, index []int, fn func(reflect.Value)) {
v = reflect.Indirect(v)
switch v.Kind() {
case reflect.Slice:
for i := 0; i < v.Len(); i++ {
visitField(v.Index(i), index, fn)
}
default:
visitField(v, index, fn)
}
}
func visitField(v reflect.Value, index []int, fn func(reflect.Value)) {
v = reflect.Indirect(v)
if len(index) > 0 {
v = v.Field(index[0])
walk(v, index[1:], fn)
} else {
fn(v)
}
}
func values(b []byte, v reflect.Value, index []int, fields []*Field) []byte {
walk(v, index, func(v reflect.Value) {
b = append(b, '(')
for i, field := range fields {
if i > 0 {
b = append(b, ", "...)
}
b = field.AppendValue(b, v, 1)
}
b = append(b, "), "...)
})
if len(b) > 0 {
b = b[:len(b)-2] // trim ", "
}
return b
}
func dstValues(model tableModel, fields []*Field) map[string][]reflect.Value {
mp := make(map[string][]reflect.Value)
var id []byte
walk(model.Root(), model.ParentIndex(), func(v reflect.Value) {
id = modelId(id[:0], v, fields)
mp[string(id)] = append(mp[string(id)], v.FieldByIndex(model.Relation().Field.Index))
})
return mp
}
func modelId(b []byte, v reflect.Value, fields []*Field) []byte {
for _, f := range fields {
b = f.AppendValue(b, v, 0)
b = append(b, ',')
}
return b
}
func modelIdMap(b []byte, m map[string]string, prefix string, fields []*Field) []byte {
for _, f := range fields {
b = append(b, m[prefix+f.SQLName]...)
b = append(b, ',')
}
return b
}
func appendFieldsColumns(b []byte, fields []*Field) []byte {
for i, f := range fields {
if i > 0 {
b = append(b, ", "...)
}
b = append(b, f.Column...)
}
return b
}
Go
1
https://gitee.com/bigbase/pg.git
git@gitee.com:bigbase/pg.git
bigbase
pg
pg
v6.2.2

搜索帮助