代码拉取完成,页面将自动刷新
package orm
import (
"strconv"
)
type CreateCompositeOptions struct {
Varchar int // replaces PostgreSQL data type `text` with `varchar(n)`
}
func CreateComposite(db DB, model interface{}, opt *CreateCompositeOptions) error {
q := NewQuery(db, model)
_, err := q.db.Exec(createCompositeQuery{
q: q,
opt: opt,
})
return err
}
type createCompositeQuery struct {
q *Query
opt *CreateCompositeOptions
}
func (q createCompositeQuery) Copy() QueryAppender {
return q
}
func (q createCompositeQuery) Query() *Query {
return q.q
}
func (q createCompositeQuery) AppendQuery(b []byte) ([]byte, error) {
if q.q.stickyErr != nil {
return nil, q.q.stickyErr
}
if q.q.model == nil {
return nil, errModelNil
}
table := q.q.model.Table()
b = append(b, "CREATE TYPE "...)
b = append(b, q.q.model.Table().Alias...)
b = append(b, " AS ("...)
for i, field := range table.Fields {
if i > 0 {
b = append(b, ", "...)
}
b = append(b, field.Column...)
b = append(b, " "...)
if q.opt != nil && q.opt.Varchar > 0 &&
field.SQLType == "text" && !field.HasFlag(customTypeFlag) {
b = append(b, "varchar("...)
b = strconv.AppendInt(b, int64(q.opt.Varchar), 10)
b = append(b, ")"...)
} else {
b = append(b, field.SQLType...)
}
}
b = append(b, ")"...)
return b, nil
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。