Documentation ¶
Index ¶
- Constants
- Variables
- func AssembleOrders(db *gorm.DB, orders []*Order) *gorm.DB
- func AssembleWheres(db *gorm.DB, wheres []*Where) *gorm.DB
- func BatchInsert(db *gorm.DB, repo BatchInsertRepo, opts ...BatchInsertOption) error
- func BatchInsertWithContext(ctx context.Context, db *gorm.DB, repo BatchInsertRepo, ...) error
- func ForShareOfTable(db *gorm.DB) *gorm.DB
- func ForUpdate(db *gorm.DB) *gorm.DB
- func ForUpdateNowait(db *gorm.DB) *gorm.DB
- func ForceIndex(db *gorm.DB, indexNameList ...string) *gorm.DB
- func IgnoreIndex(db *gorm.DB, indexNameList ...string) *gorm.DB
- func IsValidField(field string) bool
- func NewDB(dialect gorm.Dialector, connOption *ConnOption) (db *gorm.DB, err error)
- func NewDummyWriter() logger.Writer
- func NewJSONWriter(w io.Writer) logger.Writer
- func NewLogger(conf *logger.Config, writers ...logger.Writer) logger.Interface
- func NewLoggerForConn(opt *ConnOption) logger.Interface
- func NewStdWriter() logger.Writer
- func NewWriter(w io.Writer) logger.Writer
- func Paginator(db *gorm.DB, pageOption *pagepkg.PageOption) *gorm.DB
- func ParseLoggerLevel(lv string) logger.LogLevel
- func ParseOrderDirection(orderDirection string) string
- func RemoveCallback(db *gorm.DB) error
- func SetOption(db *gorm.DB, key, value string) *gorm.DB
- func UnsafeAssembleOrders(db *gorm.DB, orders []*Order) *gorm.DB
- func UnsafeAssembleWheres(db *gorm.DB, wheres []*Where) *gorm.DB
- func UseIndex(db *gorm.DB, indexNameList ...string) *gorm.DB
- type BatchInsertConflictActionReq
- type BatchInsertOption
- type BatchInsertRepo
- type BatchInsertValueArgs
- type ConnOption
- type Option
- type Order
- type PaginatorArgs
- type Where
Constants ¶
const ( OptionKeyTableOptions = "gorm:table_options" OptionKeyCreate = "gorm:create" OptionKeyUpdate = "gorm:update" OptionKeyQuery = "gorm:query" OptionKeyDelete = "gorm:delete" OptionValueEngineInnoDB = "ENGINE=InnoDB CHARSET=utf8mb4" )
const ( DefaultOrderColumn = "id" // default order column DefaultOrderAsc = "asc" // order direction : asc DefaultOrderDesc = "desc" // order direction : desc )
const (
DefaultBatchInsertConflictAlias = "excluded"
)
const (
DefaultPlaceholder = "?" // param placeholder
)
Variables ¶
var ( DefaultBatchInsertConflictActionForMySQL = BatchInsertConflictActionReq{ OnConflictValueAlias: "AS " + DefaultBatchInsertConflictAlias, OnConflictTarget: "ON DUPLICATE KEY", OnConflictAction: "UPDATE", OnConflictPrepareData: nil, } DefaultBatchInsertConflictActionPostgres = BatchInsertConflictActionReq{ OnConflictValueAlias: "", OnConflictTarget: "ON CONFLICT", OnConflictAction: "DO UPDATE SET", OnConflictPrepareData: nil, } )
Functions ¶
func AssembleOrders ¶
AssembleOrders 组装排序
func AssembleWheres ¶
AssembleWheres 组装条件
func BatchInsert ¶
func BatchInsert(db *gorm.DB, repo BatchInsertRepo, opts ...BatchInsertOption) error
BatchInsert 批量插入
func BatchInsertWithContext ¶
func BatchInsertWithContext(ctx context.Context, db *gorm.DB, repo BatchInsertRepo, opts ...BatchInsertOption) error
BatchInsertWithContext 批量插入
func ForShareOfTable ¶
ForShareOfTable FOR SHARE OF `table_name`
func IgnoreIndex ¶
IgnoreIndex 忽略使用索引
func NewLoggerForConn ¶
func NewLoggerForConn(opt *ConnOption) logger.Interface
NewLoggerForConn 数据库链接日志
func ParseOrderDirection ¶
ParseOrderDirection 排序方向
func RemoveCallback ¶
RemoveCallback 移除回调 参考文档: https://gorm.io/docs/write_plugins.html#Callbacks 参考func: callbacks.RegisterDefaultCallbacks
func UnsafeAssembleOrders ¶
UnsafeAssembleOrders 不安全的组装排序
func UnsafeAssembleWheres ¶
UnsafeAssembleWheres 不安全的组装条件
Types ¶
type BatchInsertConflictActionReq ¶
type BatchInsertConflictActionReq struct { // OnConflictValueAlias 值的别名 // MySQL : INSERT INTO ... VALUES (...) AS alias ON DUPLICATE KEY UPDATE a = alias.a // Postgres : 默认:excluded OnConflictValueAlias string // OnConflictTarget 条件 // MySQL : ON DUPLICATE KEY // Postgres : ON CONFLICT (targetColumn, ...) OnConflictTarget string // OnConflictAction 执行冲突解决方案 // MySQL : DO NOTHING OnConflictAction string // OnConflictPrepareData 冲突解决方案数据;DO UPDATE SET column_2 = ? OnConflictPrepareData []interface{} }
BatchInsertConflictActionReq 批量插入冲突解决请求
type BatchInsertOption ¶
type BatchInsertOption func(*batchInsertOptions)
BatchInsertOption 批量插入选项
func WithBatchInsertConflictAction ¶
func WithBatchInsertConflictAction(req *BatchInsertConflictActionReq) BatchInsertOption
WithBatchInsertConflictAction 执行冲突解决 MySQL : INSERT INTO ... VALUES (...) AS alias ON DUPLICATE KEY UPDATE a = alias.a Postgres : ON CONFLICT(id) DO UPDATE SET column_2= CONCAT(test_table.column_2, excluded.column_2);
func WithBatchInsertIgnore ¶
func WithBatchInsertIgnore() BatchInsertOption
WithBatchInsertIgnore 忽略重复插入 INSERT IGNORE INTO ...
type BatchInsertRepo ¶
type BatchInsertRepo interface { // TableName 表名 TableName() string // Len 数据长度 // 例子:length := len([]*User{}) Len() int // InsertColumns 插入的列 // @param columnList 插入的列名数组;例:[]string{"id","name","age"} // @param placeholder 列的占位符;例:"?, ?, ?" // 在实现此方法时:需要自行拼接占位符; InsertColumns() (columnList []string, placeholder string) // InsertValues 插入的值 // @result prepareData 插入的值;例:[]interface{}{1, "张三", 18, 2, "李四", 20, 3, "小明", 30} // @result prepareDataLen 插入的占位符;例:[]string{"(?, ?, ?)", "(?, ?, ?)", "(?, ?, ?)"} InsertValues(args *BatchInsertValueArgs) (prepareData []interface{}, placeholderSlice []string) }
BatchInsertRepo 批量插入
type BatchInsertValueArgs ¶
type BatchInsertValueArgs struct { // StepStart 开始步长:索引 StepStart int // StepEnd 结束步长:索引 StepEnd int // InsertPlaceholder 列的占位符;例:"?, ?, ?" InsertPlaceholder string // InsertSQL 入库的SQL;INSERT INTO ... VALUES (...) AS alias InsertSQL string // ConflictActionSQL 存在冲突,执行冲突动作 //insertSQL += "ON DUPLICATE KEY UPDATE " + strings.Join(s.UpdateColumnFromMtdReportData(), ",") //insertSQL += "ON CONFLICT (id) DO UPDATE SET column_2= CONCAT(test_table.column_2, excluded.column_2)" ConflictActionSQL string ConflictPrepareData []interface{} }
BatchInsertValueArgs 批量插入值的参数
type ConnOption ¶
type ConnOption struct { LoggerEnable bool LoggerLevel logger.LogLevel LoggerWriters []logger.Writer LoggerColorful bool SlowThreshold time.Duration IgnoreRecordNotFoundError bool ConnMaxActive int ConnMaxLifetime time.Duration ConnMaxIdle int ConnMaxIdleTime time.Duration }
ConnOption 连接配置
type Option ¶
type Option func(*ConnOption)
Option is config option.
func WithWriters ¶
WithWriters with config writers.
type PaginatorArgs ¶
type PaginatorArgs struct { // PageOption 分页 PageOption *pagepkg.PageOption // PageOrders 排序 PageOrders []*Order // PageWheres 条件 PageWheres []*Where }
PaginatorArgs 列表参数