sqlxz

package
v1.0.7 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Apr 6, 2021 License: Apache-2.0 Imports: 7 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func CreateUpdateSQLByNamed

func CreateUpdateSQLByNamed(tic TableIdxColumn, obj interface{},
	fix func(t reflect.Type, n string, v interface{}, f *reflect.StructField) (interface{}, bool),
	set func(c string, p map[string]interface{}, v interface{}, f *reflect.StructField) (string, bool),
) (string, map[string]interface{}, error)

CreateUpdateSQLByNamed create update sql by named

func CreateUpdateSQLByNamedAndSkipNil

func CreateUpdateSQLByNamedAndSkipNil(tic TableIdxColumn, obj interface{}) (string, map[string]interface{}, error)

CreateUpdateSQLByNamedAndSkipNil create update sql by named 忽略空字段, 空字段不进行更新, 如果需要前置更新空字段, 直接使用 CreateUpdateSQLByNamed

func CreateUpdateSQLByNamedAndSkipNilAndSet

func CreateUpdateSQLByNamedAndSkipNilAndSet(tic TableIdxColumn, obj interface{}) (string, map[string]interface{}, error)

CreateUpdateSQLByNamedAndSkipNilAndSet create update sql by named 会处理 "set" 标签的内容 , 比如 `set:"=cloumn + 1"`

func DeleteOne

func DeleteOne(sqlx *sqlx.DB, sql string, params ...interface{}) error

DeleteOne delete 1

func IsNotFound

func IsNotFound(err error) bool

IsNotFound of sqlx

func NewNowTime

func NewNowTime(t reflect.Type) interface{}

NewNowTime 获取当前时间

func PickProxy

func PickProxy(obj interface{}) interface{}

PickProxy 解除sql.NullXXX上的内容

func SelectColumns

func SelectColumns(obj interface{}) string

SelectColumns select column

func Struct2Map

func Struct2Map(obj interface{}) map[string]interface{}

Struct2Map struct to map

func UpdateAndSaveByIDWithNamed

func UpdateAndSaveByIDWithNamed(sqlx *sqlx.DB, id *Index, fn func() (string, map[string]interface{}, error)) error

UpdateAndSaveByIDWithNamed update

func WithTx

func WithTx(ctx context.Context, db *sqlx.DB, fn func(tx *sqlx.Tx) error) error

WithTx 执行带有事务的方法, 在一个事务中完成所有的内容

func WithTxV

func WithTxV(ctx context.Context, db *sqlx.DB, fn func(*sqlx.Tx) (interface{}, error)) (interface{}, error)

WithTxV 执行带有事务的方法, 在一个事务中完成所有的内容

func WithTxVx

func WithTxVx(ctx context.Context, db *sqlx.DB, rr interface{}, fn func(*sqlx.Tx, interface{}) (interface{}, error)) (interface{}, error)

WithTxVx 执行带有事务的方法, 在一个事务中完成所有的内容

Types

type Index

type Index struct {
	ID int64 `db:"id"`
}

Index id

type TableIdxColumn

type TableIdxColumn struct {
	Table  string
	IDCol  string      // index column
	IDVal  interface{} // index data
	Update sql.NullBool
	DB     *sqlx.DB
	IDCols []string               // index columns
	IDVals map[string]interface{} // index datas
}

TableIdxColumn id 1.Column="" 或者 Column = "id", 如果ID > 0 update, 否则 create 2.Update直接决定 update 或者 create 3.DB = nil 或者 Table = nil, 为 create 4.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL