sqlutil

package
v1.2.2 Latest Latest
Warning

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

Go to latest
Published: Nov 24, 2019 License: GPL-3.0 Imports: 11 Imported by: 0

Documentation

Index

Constants

View Source
const DELETE = "DELETE"
View Source
const INNER_JOIN = "INNER JOIN"
View Source
const INSERT = "INSERT"
View Source
const INSERT_OR_UPDATE = "INSERT_OR_UPDATE"
View Source
const JOIN = "JOIN"
View Source
const LEFT_JOIN = "LEFT JOIN"
View Source
const RIGHT_JOIN = "RIGHT JOIN"
View Source
const SELECT = "SELECT"
View Source
const SELECT_DISTINCT = "SELECT DISTINCT"
View Source
const UPDATE = "UPDATE"

Variables

This section is empty.

Functions

func DeleteMany

func DeleteMany(tx AbstractDBBase, query string, args ...interface{}) (rowsAffected int64, success bool)

删除多条数据

func DeleteOne

func DeleteOne(tx AbstractDBBase, query string, args ...interface{}) (rowsAffected int64, success bool)

删除一条数据

func DisableDebug

func DisableDebug()

func EnableDebug

func EnableDebug()

func FindCount

func FindCount(tx AbstractDBBase, query string, args ...interface{}) (count int64, success bool)

查询记录数量,需要 SELECT count(*) AS count FROM ... 这样的格式

func FindMany

func FindMany(tx AbstractDBBase, dest interface{}, query string, args ...interface{}) (success bool)

查询多条数据

func FindOne

func FindOne(tx AbstractDBBase, dest interface{}, query string, args ...interface{}) (success bool)

查询一条数据

func GetDefaultLocation added in v1.2.0

func GetDefaultLocation() *time.Location

func InsertMany

func InsertMany(tx AbstractDBBase, query string, args ...interface{}) (lastInsertId int64, success bool)

插入多条记录

func InsertMany2 added in v1.2.2

func InsertMany2(tx AbstractDBBase, query string, args ...interface{}) (success bool)

插入多条记录,不返回insertId

func InsertOne

func InsertOne(tx AbstractDBBase, query string, args ...interface{}) (insertId int64, success bool)

插入一条数据

func InsertOne2 added in v1.2.2

func InsertOne2(tx AbstractDBBase, query string, args ...interface{}) (success bool)

插入一条数据,不返回insertId

func InterpolateParams added in v1.2.0

func InterpolateParams(query string, args []driver.Value, loc *time.Location, quoteLiteral func([]byte, string) []byte) (string, error)

func MustOpen

func MustOpen(driverName string, dataSourceName string) *sqlx.DB

创建数据库连接,如果失败则panic

func MustOpenWithOptions

func MustOpenWithOptions(driverName string, opts ConnectionOptions) *sqlx.DB

创建数据库连接,如果失败则panic

func Open

func Open(driverName string, dataSourceName string) (*sqlx.DB, error)

创建数据库连接

func OpenWithOptions

func OpenWithOptions(driverName string, opts ConnectionOptions) (*sqlx.DB, error)

创建数据库连接

func SetDefaultLocation added in v1.2.0

func SetDefaultLocation(loc *time.Location)

func UpdateMany

func UpdateMany(tx AbstractDBBase, query string, args ...interface{}) (rowsAffected int64, success bool)

更新多条数据

func UpdateOne

func UpdateOne(tx AbstractDBBase, query string, args ...interface{}) (rowsAffected int64, success bool)

更新一条数据

Types

type AbstractDB

type AbstractDB interface {
	AbstractDBBase
	MustBegin() AbstractTx
}

type AbstractDBBase

type AbstractDBBase interface {
	Get(dest interface{}, query string, args ...interface{}) error
	Select(dest interface{}, query string, args ...interface{}) error
	Exec(query string, args ...interface{}) (sql.Result, error)
}

type AbstractTx

type AbstractTx interface {
	AbstractDBBase
	Rollback() error
	Commit() error
}

type ConnectionOptions added in v1.2.0

type ConnectionOptions interface {
	BuildDataSourceString() string
}

type DB

type DB = sqlx.DB

type QueryBuilder added in v1.2.0

type QueryBuilder struct {
	// contains filtered or unexported fields
}

func NewEmptyQuery added in v1.2.0

func NewEmptyQuery() *QueryBuilder

func Table added in v1.2.0

func Table(tableName string) *QueryBuilder

func (*QueryBuilder) And added in v1.2.0

func (q *QueryBuilder) And(query string, args ...driver.Value) *QueryBuilder

func (*QueryBuilder) AndRow added in v1.2.0

func (q *QueryBuilder) AndRow(row Row) *QueryBuilder

func (*QueryBuilder) As added in v1.2.0

func (q *QueryBuilder) As(name string) *QueryBuilder

func (*QueryBuilder) Build added in v1.2.0

func (q *QueryBuilder) Build() string

func (*QueryBuilder) Clone added in v1.2.0

func (q *QueryBuilder) Clone() *QueryBuilder

func (*QueryBuilder) Count added in v1.2.0

func (q *QueryBuilder) Count(field string) *QueryBuilder

func (*QueryBuilder) Delete added in v1.2.0

func (q *QueryBuilder) Delete() *QueryBuilder

func (*QueryBuilder) Fields added in v1.2.0

func (q *QueryBuilder) Fields(fields ...string) *QueryBuilder

func (*QueryBuilder) Format added in v1.2.0

func (q *QueryBuilder) Format(query string, args ...driver.Value) string

func (*QueryBuilder) GroupBy added in v1.2.0

func (q *QueryBuilder) GroupBy(tpl string, args ...driver.Value) *QueryBuilder

func (*QueryBuilder) Having added in v1.2.0

func (q *QueryBuilder) Having(tpl string, args ...driver.Value) *QueryBuilder

func (*QueryBuilder) Init added in v1.2.0

func (q *QueryBuilder) Init(quoteIdentifier func(id string) string, quoteLiteral func([]byte, string) []byte) *QueryBuilder

func (*QueryBuilder) InnerJoin added in v1.2.0

func (q *QueryBuilder) InnerJoin(tableName string, fields ...string) *QueryBuilder

func (*QueryBuilder) Insert added in v1.2.0

func (q *QueryBuilder) Insert(row Row) *QueryBuilder

func (*QueryBuilder) InsertMany added in v1.2.0

func (q *QueryBuilder) InsertMany(rows []Row) *QueryBuilder

func (*QueryBuilder) Join added in v1.2.0

func (q *QueryBuilder) Join(tableName string, fields ...string) *QueryBuilder

func (*QueryBuilder) LeftJoin added in v1.2.0

func (q *QueryBuilder) LeftJoin(tableName string, fields ...string) *QueryBuilder

func (*QueryBuilder) Limit added in v1.2.0

func (q *QueryBuilder) Limit(n int) *QueryBuilder

func (*QueryBuilder) Location added in v1.2.0

func (q *QueryBuilder) Location(loc *time.Location) *QueryBuilder

func (*QueryBuilder) On added in v1.2.0

func (q *QueryBuilder) On(condition string, args ...driver.Value) *QueryBuilder

func (*QueryBuilder) OnDuplicateKeyUpdate added in v1.2.0

func (q *QueryBuilder) OnDuplicateKeyUpdate() *QueryBuilder

func (*QueryBuilder) OrderBy added in v1.2.0

func (q *QueryBuilder) OrderBy(tpl string, args ...driver.Value) *QueryBuilder

func (*QueryBuilder) QuoteIdentifier added in v1.2.0

func (q *QueryBuilder) QuoteIdentifier(id string) string

func (*QueryBuilder) RightJoin added in v1.2.0

func (q *QueryBuilder) RightJoin(tableName string, fields ...string) *QueryBuilder

func (*QueryBuilder) Select added in v1.2.0

func (q *QueryBuilder) Select(fields ...string) *QueryBuilder

func (*QueryBuilder) SelectDistinct added in v1.2.0

func (q *QueryBuilder) SelectDistinct(fields ...string) *QueryBuilder

func (*QueryBuilder) Set added in v1.2.0

func (q *QueryBuilder) Set(update string, args ...driver.Value) *QueryBuilder

func (*QueryBuilder) SetRow added in v1.2.0

func (q *QueryBuilder) SetRow(row Row) *QueryBuilder

func (*QueryBuilder) Skip added in v1.2.0

func (q *QueryBuilder) Skip(n int) *QueryBuilder

func (*QueryBuilder) Table added in v1.2.0

func (q *QueryBuilder) Table(tableName string) *QueryBuilder

func (*QueryBuilder) Update added in v1.2.0

func (q *QueryBuilder) Update() *QueryBuilder

func (*QueryBuilder) Where added in v1.2.0

func (q *QueryBuilder) Where(query string, args ...driver.Value) *QueryBuilder

func (*QueryBuilder) WhereRow added in v1.2.0

func (q *QueryBuilder) WhereRow(row Row) *QueryBuilder

type QueryCountRow

type QueryCountRow struct {
	Count int64 `db:"count"`
}

type Row

type Row = map[string]interface{}

type Tx

type Tx = sqlx.Tx

Directories

Path Synopsis

Jump to

Keyboard shortcuts

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