Documentation ¶
Overview ¶
Package builder is a simple and powerful sql builder for Go.
Make sure you have installed Go 1.1+ and then:
go get github.com/yyythinking/xormplus/builder
WARNNING: Currently, only query conditions are supported. Below is the supported conditions.
1. Eq is a redefine of a map, you can give one or more conditions to Eq
import . "github.com/yyythinking/xormplus/builder" sql, args, _ := ToSQL(Eq{"a":1}) // a=? [1] sql, args, _ := ToSQL(Eq{"b":"c"}.And(Eq{"c": 0})) // b=? AND c=? ["c", 0] sql, args, _ := ToSQL(Eq{"b":"c", "c":0}) // b=? AND c=? ["c", 0] sql, args, _ := ToSQL(Eq{"b":"c"}.Or(Eq{"b":"d"})) // b=? OR b=? ["c", "d"] sql, args, _ := ToSQL(Eq{"b": []string{"c", "d"}}) // b IN (?,?) ["c", "d"] sql, args, _ := ToSQL(Eq{"b": 1, "c":[]int{2, 3}}) // b=? AND c IN (?,?) [1, 2, 3]
2. Neq is the same to Eq
import . "github.com/yyythinking/xormplus/builder" sql, args, _ := ToSQL(Neq{"a":1}) // a<>? [1] sql, args, _ := ToSQL(Neq{"b":"c"}.And(Neq{"c": 0})) // b<>? AND c<>? ["c", 0] sql, args, _ := ToSQL(Neq{"b":"c", "c":0}) // b<>? AND c<>? ["c", 0] sql, args, _ := ToSQL(Neq{"b":"c"}.Or(Neq{"b":"d"})) // b<>? OR b<>? ["c", "d"] sql, args, _ := ToSQL(Neq{"b": []string{"c", "d"}}) // b NOT IN (?,?) ["c", "d"] sql, args, _ := ToSQL(Neq{"b": 1, "c":[]int{2, 3}}) // b<>? AND c NOT IN (?,?) [1, 2, 3]
3. Gt, Gte, Lt, Lte
import . "github.com/yyythinking/xormplus/builder" sql, args, _ := ToSQL(Gt{"a", 1}.And(Gte{"b", 2})) // a>? AND b>=? [1, 2] sql, args, _ := ToSQL(Lt{"a", 1}.Or(Lte{"b", 2})) // a<? OR b<=? [1, 2]
4. Like
import . "github.com/yyythinking/xormplus/builder" sql, args, _ := ToSQL(Like{"a", "c"}) // a LIKE ? [%c%]
5. Expr you can customerize your sql with Expr
import . "github.com/yyythinking/xormplus/builder" sql, args, _ := ToSQL(Expr("a = ? ", 1)) // a = ? [1] sql, args, _ := ToSQL(Eq{"a": Expr("select id from table where c = ?", 1)}) // a=(select id from table where c = ?) [1]
6. In and NotIn
import . "github.com/yyythinking/xormplus/builder" sql, args, _ := ToSQL(In("a", 1, 2, 3)) // a IN (?,?,?) [1,2,3] sql, args, _ := ToSQL(In("a", []int{1, 2, 3})) // a IN (?,?,?) [1,2,3] sql, args, _ := ToSQL(In("a", Expr("select id from b where c = ?", 1)))) // a IN (select id from b where c = ?) [1]
7. IsNull and NotNull
import . "github.com/yyythinking/xormplus/builder" sql, args, _ := ToSQL(IsNull{"a"}) // a IS NULL [] sql, args, _ := ToSQL(NotNull{"b"}) // b IS NOT NULL []
8. And(conds ...Cond), And can connect one or more condtions via AND
import . "github.com/yyythinking/xormplus/builder" sql, args, _ := ToSQL(And(Eq{"a":1}, Like{"b", "c"}, Neq{"d", 2})) // a=? AND b LIKE ? AND d<>? [1, %c%, 2]
9. Or(conds ...Cond), Or can connect one or more conditions via Or
import . "github.com/yyythinking/xormplus/builder" sql, args, _ := ToSQL(Or(Eq{"a":1}, Like{"b", "c"}, Neq{"d", 2})) // a=? OR b LIKE ? OR d<>? [1, %c%, 2] sql, args, _ := ToSQL(Or(Eq{"a":1}, And(Like{"b", "c"}, Neq{"d", 2}))) // a=? OR (b LIKE ? AND d<>?) [1, %c%, 2]
10. Between
import . "github.com/yyythinking/xormplus/builder" sql, args, _ := ToSQL(Between("a", 1, 2)) // a BETWEEN 1 AND 2
11. define yourself conditions Since Cond is a interface, you can define yourself conditions and compare with them
Index ¶
- Constants
- Variables
- func ConvertPlaceholder(sql, prefix string) (string, error)
- func ConvertToBoundSQL(sql string, args []interface{}) (string, error)
- func ToBoundSQL(cond interface{}) (string, error)
- func ToSQL(cond interface{}) (string, []interface{}, error)
- func WriteMap(w Writer, data map[string]interface{}, op string) error
- type Between
- type Builder
- func Delete(conds ...Cond) *Builder
- func Dialect(dialect string) *Builder
- func Insert(eq ...interface{}) *Builder
- func MsSQL() *Builder
- func MySQL() *Builder
- func Oracle() *Builder
- func Postgres() *Builder
- func SQLite() *Builder
- func Select(cols ...string) *Builder
- func Update(updates ...Cond) *Builder
- func (b *Builder) And(cond Cond) *Builder
- func (b *Builder) CrossJoin(joinTable, joinCond interface{}) *Builder
- func (b *Builder) Delete(conds ...Cond) *Builder
- func (b *Builder) Except(distinctType string, cond *Builder) *Builder
- func (b *Builder) From(subject interface{}, alias ...string) *Builder
- func (b *Builder) FullJoin(joinTable, joinCond interface{}) *Builder
- func (b *Builder) GroupBy(groupby string) *Builder
- func (b *Builder) Having(having string) *Builder
- func (b *Builder) InnerJoin(joinTable, joinCond interface{}) *Builder
- func (b *Builder) Insert(eq ...interface{}) *Builder
- func (b *Builder) Intersect(distinctType string, cond *Builder) *Builder
- func (b *Builder) Into(tableName string) *Builder
- func (b *Builder) Join(joinType string, joinTable, joinCond interface{}) *Builder
- func (b *Builder) LeftJoin(joinTable, joinCond interface{}) *Builder
- func (b *Builder) Limit(limitN int, offset ...int) *Builder
- func (b *Builder) Or(cond Cond) *Builder
- func (b *Builder) OrderBy(orderBy string) *Builder
- func (b *Builder) RightJoin(joinTable, joinCond interface{}) *Builder
- func (b *Builder) Select(cols ...string) *Builder
- func (b *Builder) TableName() string
- func (b *Builder) ToBoundSQL() (string, error)
- func (b *Builder) ToSQL() (string, []interface{}, error)
- func (b *Builder) Union(distinctType string, cond *Builder) *Builder
- func (b *Builder) Update(updates ...Cond) *Builder
- func (b *Builder) Where(cond Cond) *Builder
- func (b *Builder) WriteTo(w Writer) error
- type BytesWriter
- type Cond
- type Decr
- type Eq
- type Gt
- type Gte
- type Incr
- type IsNull
- type Like
- type Lt
- type Lte
- type Neq
- type Not
- type NotNull
- type UpdateCond
- type Writer
Constants ¶
const ( POSTGRES = "postgres" SQLITE = "sqlite3" MYSQL = "mysql" MSSQL = "mssql" ORACLE = "oracle" UNION = "union" INTERSECT = "intersect" EXCEPT = "except" )
all databasees
Variables ¶
var ( // ErrNotSupportType not supported SQL type error ErrNotSupportType = errors.New("Not supported SQL type") // ErrNoNotInConditions no NOT IN params error ErrNoNotInConditions = errors.New("No NOT IN conditions") // ErrNoInConditions no IN params error ErrNoInConditions = errors.New("No IN conditions") // ErrNeedMoreArguments need more arguments ErrNeedMoreArguments = errors.New("Need more sql arguments") // ErrNoTableName no table name ErrNoTableName = errors.New("No table indicated") // ErrNoColumnToUpdate no column to update ErrNoColumnToUpdate = errors.New("No column(s) to update") // ErrNoColumnToInsert no column to insert ErrNoColumnToInsert = errors.New("No column(s) to insert") // ErrNotSupportDialectType not supported dialect type error ErrNotSupportDialectType = errors.New("Not supported dialect type") // ErrNotUnexpectedUnionConditions using union in a wrong way ErrNotUnexpectedUnionConditions = errors.New("Unexpected conditional fields in UNION query") // ErrUnsupportedUnionMembers unexpected members in UNION query ErrUnsupportedUnionMembers = errors.New("Unexpected members in UNION query") // ErrUnexpectedSubQuery Unexpected sub-query in SELECT query ErrUnexpectedSubQuery = errors.New("Unexpected sub-query in SELECT query") // ErrDialectNotSetUp dialect is not setup yet ErrDialectNotSetUp = errors.New("Dialect is not setup yet, try to use `Dialect(dbType)` at first") // ErrInvalidLimitation offset or limit is not correct ErrInvalidLimitation = errors.New("Offset or limit is not correct") // ErrUnnamedDerivedTable Every derived table must have its own alias ErrUnnamedDerivedTable = errors.New("Every derived table must have its own alias") // ErrInconsistentDialect Inconsistent dialect in same builder ErrInconsistentDialect = errors.New("Inconsistent dialect in same builder") )
Functions ¶
func ConvertPlaceholder ¶
ConvertPlaceholder replaces the place holder ? to $1, $2 ... or :1, :2 ... according prefix
func ConvertToBoundSQL ¶
ConvertToBoundSQL will convert SQL and args to a bound SQL
func ToBoundSQL ¶
ToBoundSQL convert a builder or conditions to parameters bound SQL
Types ¶
type Between ¶
type Between struct { Col string LessVal interface{} MoreVal interface{} }
Between implmentes between condition
type Builder ¶
type Builder struct {
// contains filtered or unexported fields
}
Builder describes a SQL statement
func (*Builder) From ¶
From sets from subject(can be a table name in string or a builder pointer) and its alias
func (*Builder) ToBoundSQL ¶
ToBoundSQL generated a bound SQL string
type BytesWriter ¶
BytesWriter implments Writer and save SQL in bytes.Buffer
func (*BytesWriter) Append ¶
func (w *BytesWriter) Append(args ...interface{})
Append appends args to Writer
type Eq ¶
type Eq map[string]interface{}
Eq defines equals conditions
type IsNull ¶
type IsNull [1]string
IsNull defines IS NULL condition
type NotNull ¶
type NotNull [1]string
NotNull defines NOT NULL condition
type UpdateCond ¶
UpdateCond defines an interface that cond could be used with update
Source Files ¶
- builder.go
- builder_delete.go
- builder_insert.go
- builder_join.go
- builder_limit.go
- builder_select.go
- builder_set_operations.go
- builder_update.go
- cond.go
- cond_and.go
- cond_between.go
- cond_compare.go
- cond_eq.go
- cond_expr.go
- cond_if.go
- cond_in.go
- cond_like.go
- cond_neq.go
- cond_not.go
- cond_notin.go
- cond_null.go
- cond_or.go
- doc.go
- error.go
- sql.go
- writer.go