Documentation ¶
Index ¶
- func RowFloat64(r *Row, field Field) float64
- func RowFloat64Valid(r *Row, field Field) bool
- func RowInt(r *Row, field Field) int
- func RowInt64(r *Row, field NumberField) int64
- func RowInt64Valid(r *Row, field NumberField) bool
- func RowIntValid(r *Row, field Field) bool
- func RowNullFloat64(r *Row, field Field) sql.NullFloat64
- func RowNullInt64(r *Row, field Field) sql.NullInt64
- func RowNullString(r *Row, field Field) sql.NullString
- func RowNullTime(r *Row, field Field) sql.NullTime
- func RowString(r *Row, field Field) string
- func RowStringValid(r *Row, field Field) bool
- func RowTime(r *Row, field Field) time.Time
- func RowTimeValid(r *Row, field Field) bool
- func SelectDistinctOn(distinctFields ...Field) func(...Field) SelectQuery
- type ArrayField
- func (f ArrayField) AppendSQLExclude(buf *strings.Builder, args *[]interface{}, excludedTableQualifiers []string)
- func (f ArrayField) As(alias string) ArrayField
- func (f ArrayField) Asc() ArrayField
- func (f ArrayField) Concat(field ArrayField) Field
- func (f ArrayField) ContainedBy(field ArrayField) Predicate
- func (f ArrayField) Contains(field ArrayField) Predicate
- func (f ArrayField) Desc() ArrayField
- func (f ArrayField) Eq(field ArrayField) Predicate
- func (f ArrayField) Ge(field ArrayField) Predicate
- func (f ArrayField) GetAlias() string
- func (f ArrayField) GetName() string
- func (f ArrayField) Gt(field ArrayField) Predicate
- func (f ArrayField) IsNotNull() Predicate
- func (f ArrayField) IsNull() Predicate
- func (f ArrayField) Le(field ArrayField) Predicate
- func (f ArrayField) Lt(field ArrayField) Predicate
- func (f ArrayField) Ne(field ArrayField) Predicate
- func (f ArrayField) NullsFirst() ArrayField
- func (f ArrayField) NullsLast() ArrayField
- func (f ArrayField) Overlaps(field ArrayField) Predicate
- func (f ArrayField) Set(value ArrayField) FieldAssignment
- func (f ArrayField) String() string
- type Assignment
- type Assignments
- type BaseQuery
- func (q BaseQuery) DeleteFrom(table BaseTable) DeleteQuery
- func (q BaseQuery) From(table Table) SelectQuery
- func (q BaseQuery) InsertInto(table BaseTable) InsertQuery
- func (q BaseQuery) Select(fields ...Field) SelectQuery
- func (q BaseQuery) SelectAll() SelectQuery
- func (q BaseQuery) SelectCount() SelectQuery
- func (q BaseQuery) SelectDistinct(fields ...Field) SelectQuery
- func (q BaseQuery) SelectDistinctOn(distinctFields ...Field) func(...Field) SelectQuery
- func (q BaseQuery) SelectOne() SelectQuery
- func (q BaseQuery) SelectRowx(mapper func(*Row)) SelectQuery
- func (q BaseQuery) Selectx(mapper func(*Row), accumulator func()) SelectQuery
- func (q BaseQuery) Union(queries ...Query) VariadicQuery
- func (q BaseQuery) UnionAll(queries ...Query) VariadicQuery
- func (q BaseQuery) Update(table BaseTable) UpdateQuery
- func (q BaseQuery) With(CTEs ...CTE) BaseQuery
- func (q BaseQuery) WithDB(db DB) BaseQuery
- func (q BaseQuery) WithDefaultLog(flag LogFlag) BaseQuery
- type BaseTable
- type BinaryField
- func (f BinaryField) AppendSQLExclude(buf *strings.Builder, args *[]interface{}, excludedTableQualifiers []string)
- func (f BinaryField) GetAlias() string
- func (f BinaryField) GetName() string
- func (f BinaryField) IsNotNull() Predicate
- func (f BinaryField) IsNull() Predicate
- func (f BinaryField) Set(v interface{}) FieldAssignment
- func (f BinaryField) SetBytes(b []byte) FieldAssignment
- type BooleanField
- func (f BooleanField) AppendSQLExclude(buf *strings.Builder, args *[]interface{}, excludedTableQualifiers []string)
- func (f BooleanField) As(alias string) BooleanField
- func (f BooleanField) Asc() BooleanField
- func (f BooleanField) Desc() BooleanField
- func (f BooleanField) Eq(field BooleanField) Predicate
- func (f BooleanField) GetAlias() string
- func (f BooleanField) GetName() string
- func (f BooleanField) IsNotNull() Predicate
- func (f BooleanField) IsNull() Predicate
- func (f BooleanField) Ne(field BooleanField) Predicate
- func (f BooleanField) Not() Predicate
- func (f BooleanField) NullsFirst() BooleanField
- func (f BooleanField) NullsLast() BooleanField
- func (f BooleanField) Set(val interface{}) FieldAssignment
- func (f BooleanField) SetBool(val bool) FieldAssignment
- func (f BooleanField) String() string
- type CTE
- func (cte CTE) AppendSQL(buf *strings.Builder, _ *[]interface{})
- func (cte CTE) As(alias string) CTE
- func (cte CTE) GetAlias() string
- func (cte CTE) GetColumns() []string
- func (cte CTE) GetName() string
- func (cte CTE) GetQuery() Query
- func (cte *CTE) Initial(query Query) IntermediateCTE
- func (cte CTE) IsRecursive() bool
- type Column
- func (col *Column) Set(field Field, value interface{})
- func (col *Column) SetBool(field BooleanField, value bool)
- func (col *Column) SetFloat64(field NumberField, value float64)
- func (col *Column) SetInt(field NumberField, value int)
- func (col *Column) SetInt64(field NumberField, value int64)
- func (col *Column) SetString(field StringField, value string)
- func (col *Column) SetTime(field TimeField, value time.Time)
- type CustomAssignment
- type CustomField
- func (f CustomField) AppendSQLExclude(buf *strings.Builder, args *[]interface{}, excludedTableQualifiers []string)
- func (f CustomField) As(alias string) CustomField
- func (f CustomField) Asc() CustomField
- func (f CustomField) Desc() CustomField
- func (f CustomField) Eq(v interface{}) Predicate
- func (f CustomField) Ge(v interface{}) Predicate
- func (f CustomField) GetAlias() string
- func (f CustomField) GetName() string
- func (f CustomField) Gt(v interface{}) Predicate
- func (f CustomField) In(v interface{}) Predicate
- func (f CustomField) IsNotNull() Predicate
- func (f CustomField) IsNull() Predicate
- func (f CustomField) Le(v interface{}) Predicate
- func (f CustomField) Lt(v interface{}) Predicate
- func (f CustomField) Ne(v interface{}) Predicate
- func (f CustomField) NullsFirst() CustomField
- func (f CustomField) NullsLast() CustomField
- func (f CustomField) String() string
- type CustomPredicate
- func (p CustomPredicate) AppendSQLExclude(buf *strings.Builder, args *[]interface{}, excludedTableQualifiers []string)
- func (p CustomPredicate) As(alias string) CustomPredicate
- func (p CustomPredicate) GetAlias() string
- func (p CustomPredicate) GetName() string
- func (p CustomPredicate) Not() Predicate
- type DB
- type DeleteQuery
- func (q DeleteQuery) AppendSQL(buf *strings.Builder, args *[]interface{})
- func (q DeleteQuery) CTE(name string, columns ...string) CTE
- func (q DeleteQuery) CustomJoin(joinType JoinType, table Table, predicates ...Predicate) DeleteQuery
- func (q DeleteQuery) DeleteFrom(table BaseTable) DeleteQuery
- func (q DeleteQuery) Exec(db DB, flag ExecFlag) (rowsAffected int64, err error)
- func (q DeleteQuery) ExecContext(ctx context.Context, db DB, flag ExecFlag) (rowsAffected int64, err error)
- func (q DeleteQuery) Fetch(db DB) (err error)
- func (q DeleteQuery) FetchContext(ctx context.Context, db DB) (err error)
- func (q DeleteQuery) FullJoin(table Table, predicate Predicate, predicates ...Predicate) DeleteQuery
- func (q DeleteQuery) GetName() string
- func (q DeleteQuery) Join(table Table, predicate Predicate, predicates ...Predicate) DeleteQuery
- func (q DeleteQuery) LeftJoin(table Table, predicate Predicate, predicates ...Predicate) DeleteQuery
- func (q DeleteQuery) NestThis() Query
- func (q DeleteQuery) Returning(fields ...Field) DeleteQuery
- func (q DeleteQuery) ReturningOne() DeleteQuery
- func (q DeleteQuery) ReturningRowx(mapper func(*Row)) DeleteQuery
- func (q DeleteQuery) Returningx(mapper func(*Row), accumulator func()) DeleteQuery
- func (q DeleteQuery) RightJoin(table Table, predicate Predicate, predicates ...Predicate) DeleteQuery
- func (q DeleteQuery) Subquery(alias string) Subquery
- func (q DeleteQuery) ToSQL() (string, []interface{})
- func (q DeleteQuery) Using(table Table) DeleteQuery
- func (q DeleteQuery) Where(predicates ...Predicate) DeleteQuery
- func (q DeleteQuery) With(ctes ...CTE) DeleteQuery
- type EnumField
- type ExecFlag
- type ExitCode
- type Field
- type FieldAssignment
- type FieldLiteral
- type Fields
- type FunctionInfo
- type InsertConflict
- type InsertQuery
- func (q InsertQuery) AppendSQL(buf *strings.Builder, args *[]interface{})
- func (q InsertQuery) CTE(name string, columns ...string) CTE
- func (q InsertQuery) Columns(fields ...Field) InsertQuery
- func (q InsertQuery) Exec(db DB, flag ExecFlag) (rowsAffected int64, err error)
- func (q InsertQuery) ExecContext(ctx context.Context, db DB, flag ExecFlag) (rowsAffected int64, err error)
- func (q InsertQuery) Fetch(db DB) (err error)
- func (q InsertQuery) FetchContext(ctx context.Context, db DB) (err error)
- func (q InsertQuery) InsertInto(table BaseTable) InsertQuery
- func (q InsertQuery) InsertRow(assignments ...FieldAssignment) InsertQuery
- func (q InsertQuery) NestThis() Query
- func (q InsertQuery) OnConflict(fields ...Field) InsertConflict
- func (q InsertQuery) OnConflictOnConstraint(name string) InsertConflict
- func (q InsertQuery) Returning(fields ...Field) InsertQuery
- func (q InsertQuery) ReturningOne() InsertQuery
- func (q InsertQuery) ReturningRowx(mapper func(*Row)) InsertQuery
- func (q InsertQuery) Returningx(mapper func(*Row), accumulator func()) InsertQuery
- func (q InsertQuery) Select(selectQuery SelectQuery) InsertQuery
- func (q InsertQuery) Subquery(alias string) Subquery
- func (q InsertQuery) ToSQL() (string, []interface{})
- func (q InsertQuery) Values(values ...interface{}) InsertQuery
- func (q InsertQuery) Valuesx(mapper func(*Column)) InsertQuery
- func (q InsertQuery) Where(predicates ...Predicate) InsertQuery
- func (q InsertQuery) With(ctes ...CTE) InsertQuery
- type IntermediateCTE
- type JSONField
- func (f JSONField) AppendSQLExclude(buf *strings.Builder, args *[]interface{}, excludedTableQualifiers []string)
- func (f JSONField) As(alias string) JSONField
- func (f JSONField) Asc() JSONField
- func (f JSONField) Desc() JSONField
- func (f JSONField) GetAlias() string
- func (f JSONField) GetName() string
- func (f JSONField) IsNotNull() Predicate
- func (f JSONField) IsNull() Predicate
- func (f JSONField) NullsFirst() JSONField
- func (f JSONField) NullsLast() JSONField
- func (f JSONField) Set(value interface{}) FieldAssignment
- func (f JSONField) SetJSON(value interface{}) FieldAssignment
- func (f JSONField) SetValue(value driver.Valuer) FieldAssignment
- func (f JSONField) String() string
- type JoinTable
- func CustomJoin(joinType JoinType, table Table, predicates ...Predicate) JoinTable
- func FullJoin(table Table, predicates ...Predicate) JoinTable
- func Join(table Table, predicates ...Predicate) JoinTable
- func LeftJoin(table Table, predicates ...Predicate) JoinTable
- func RightJoin(table Table, predicates ...Predicate) JoinTable
- type JoinTables
- type JoinType
- type LogFlag
- type Logger
- type NumberField
- func Avg(field interface{}) NumberField
- func AvgOver(field interface{}, window Window) NumberField
- func Count() NumberField
- func CountOver(window Window) NumberField
- func Float64(num float64) NumberField
- func Int(num int) NumberField
- func Int64(num int64) NumberField
- func Max(field interface{}) NumberField
- func MaxOver(field interface{}, window Window) NumberField
- func Min(field interface{}) NumberField
- func MinOver(field interface{}, window Window) NumberField
- func NewNumberField(name string, table Table) NumberField
- func NumberFieldf(format string, values ...interface{}) NumberField
- func Sum(field interface{}) NumberField
- func SumOver(field interface{}, window Window) NumberField
- func (f NumberField) AppendSQLExclude(buf *strings.Builder, args *[]interface{}, excludedTableQualifiers []string)
- func (f NumberField) As(alias string) NumberField
- func (f NumberField) Asc() NumberField
- func (f NumberField) Desc() NumberField
- func (f NumberField) Eq(field NumberField) Predicate
- func (f NumberField) EqFloat64(num float64) Predicate
- func (f NumberField) EqInt(num int) Predicate
- func (f NumberField) Ge(field NumberField) Predicate
- func (f NumberField) GeFloat64(num float64) Predicate
- func (f NumberField) GeInt(num int) Predicate
- func (f NumberField) GetAlias() string
- func (f NumberField) GetName() string
- func (f NumberField) Gt(field NumberField) Predicate
- func (f NumberField) GtFloat64(num float64) Predicate
- func (f NumberField) GtInt(num int) Predicate
- func (f NumberField) In(v interface{}) Predicate
- func (f NumberField) IsNotNull() Predicate
- func (f NumberField) IsNull() Predicate
- func (f NumberField) Le(field NumberField) Predicate
- func (f NumberField) LeFloat64(num float64) Predicate
- func (f NumberField) LeInt(num int) Predicate
- func (f NumberField) Lt(field NumberField) Predicate
- func (f NumberField) LtFloat64(num float64) Predicate
- func (f NumberField) LtInt(num int) Predicate
- func (f NumberField) Ne(field NumberField) Predicate
- func (f NumberField) NeFloat64(num float64) Predicate
- func (f NumberField) NeInt(num int) Predicate
- func (f NumberField) NullsFirst() NumberField
- func (f NumberField) NullsLast() NumberField
- func (f NumberField) Set(val interface{}) FieldAssignment
- func (f NumberField) SetFloat64(num float64) FieldAssignment
- func (f NumberField) SetInt(num int) FieldAssignment
- func (f NumberField) SetInt64(num int64) FieldAssignment
- func (f NumberField) String() string
- type Predicate
- type PredicateCase
- type PredicateCases
- func (f PredicateCases) AppendSQLExclude(buf *strings.Builder, args *[]interface{}, excludedTableQualifiers []string)
- func (f PredicateCases) As(alias string) PredicateCases
- func (f PredicateCases) Else(fallback interface{}) PredicateCases
- func (f PredicateCases) GetAlias() string
- func (f PredicateCases) GetName() string
- func (f PredicateCases) When(predicate Predicate, result interface{}) PredicateCases
- type Query
- type Row
- func (r *Row) Bool(predicate Predicate) bool
- func (r *Row) BoolValid(predicate Predicate) bool
- func (r *Row) Float64(field NumberField) float64
- func (r *Row) Float64Valid(field NumberField) bool
- func (r *Row) Int(field NumberField) int
- func (r *Row) Int64(field NumberField) int64
- func (r *Row) Int64Valid(field NumberField) bool
- func (r *Row) IntValid(field NumberField) bool
- func (r *Row) NullBool(predicate Predicate) sql.NullBool
- func (r *Row) NullFloat64(field NumberField) sql.NullFloat64
- func (r *Row) NullInt64(field NumberField) sql.NullInt64
- func (r *Row) NullString(field StringField) sql.NullString
- func (r *Row) NullTime(field TimeField) sql.NullTime
- func (r *Row) ScanArray(slice interface{}, field Field)
- func (r *Row) ScanInto(dest interface{}, field Field)
- func (r *Row) String(field StringField) string
- func (r *Row) StringValid(field StringField) bool
- func (r *Row) Time(field TimeField) time.Time
- func (r *Row) TimeValid(field TimeField) bool
- type RowValue
- func (r RowValue) AppendSQL(buf *strings.Builder, args *[]interface{})
- func (r RowValue) AppendSQLExclude(buf *strings.Builder, args *[]interface{}, excludedTableQualifiers []string)
- func (r RowValue) GetAlias() string
- func (r RowValue) GetName() string
- func (r RowValue) In(v interface{}) CustomPredicate
- func (r RowValue) Set(v interface{}) CustomAssignment
- type RowValues
- type SelectQuery
- func (q SelectQuery) AppendSQL(buf *strings.Builder, args *[]interface{})
- func (q SelectQuery) CTE(name string, columns ...string) CTE
- func (q SelectQuery) CustomJoin(joinType JoinType, table Table, predicates ...Predicate) SelectQuery
- func (q SelectQuery) Exec(db DB, flag ExecFlag) (rowsAffected int64, err error)
- func (q SelectQuery) ExecContext(ctx context.Context, db DB, flag ExecFlag) (rowsAffected int64, err error)
- func (q SelectQuery) Fetch(db DB) (err error)
- func (q SelectQuery) FetchContext(ctx context.Context, db DB) (err error)
- func (q SelectQuery) From(table Table) SelectQuery
- func (q SelectQuery) FullJoin(table Table, predicate Predicate, predicates ...Predicate) SelectQuery
- func (q SelectQuery) GroupBy(fields ...Field) SelectQuery
- func (q SelectQuery) Having(predicates ...Predicate) SelectQuery
- func (q SelectQuery) Join(table Table, predicate Predicate, predicates ...Predicate) SelectQuery
- func (q SelectQuery) LeftJoin(table Table, predicate Predicate, predicates ...Predicate) SelectQuery
- func (q SelectQuery) Limit(limit int) SelectQuery
- func (q SelectQuery) NestThis() Query
- func (q SelectQuery) Offset(offset int) SelectQuery
- func (q SelectQuery) OrderBy(fields ...Field) SelectQuery
- func (q SelectQuery) RightJoin(table Table, predicate Predicate, predicates ...Predicate) SelectQuery
- func (q SelectQuery) Select(fields ...Field) SelectQuery
- func (q SelectQuery) SelectAll() SelectQuery
- func (q SelectQuery) SelectCount() SelectQuery
- func (q SelectQuery) SelectDistinct(fields ...Field) SelectQuery
- func (q SelectQuery) SelectDistinctOn(distinctFields ...Field) func(...Field) SelectQuery
- func (q SelectQuery) SelectOne() SelectQuery
- func (q SelectQuery) SelectRowx(mapper func(*Row)) SelectQuery
- func (q SelectQuery) Selectx(mapper func(*Row), accumulator func()) SelectQuery
- func (q SelectQuery) Subquery(alias string) Subquery
- func (q SelectQuery) ToSQL() (string, []interface{})
- func (q SelectQuery) Where(predicates ...Predicate) SelectQuery
- func (q SelectQuery) Window(windows ...Window) SelectQuery
- func (q SelectQuery) With(ctes ...CTE) SelectQuery
- type SelectType
- type SimpleCase
- type SimpleCases
- func (f SimpleCases) AppendSQLExclude(buf *strings.Builder, args *[]interface{}, excludedTableQualifiers []string)
- func (f SimpleCases) As(alias string) SimpleCases
- func (f SimpleCases) Else(field Field) SimpleCases
- func (f SimpleCases) GetAlias() string
- func (f SimpleCases) GetName() string
- func (f SimpleCases) When(field Field, result Field) SimpleCases
- type StringField
- func (f StringField) AppendSQLExclude(buf *strings.Builder, args *[]interface{}, excludedTableQualifiers []string)
- func (f StringField) As(alias string) StringField
- func (f StringField) Asc() StringField
- func (f StringField) Desc() StringField
- func (f StringField) Eq(field StringField) Predicate
- func (f StringField) EqString(s string) Predicate
- func (f StringField) Ge(field StringField) Predicate
- func (f StringField) GeString(s string) Predicate
- func (f StringField) GetAlias() string
- func (f StringField) GetName() string
- func (f StringField) Gt(field StringField) Predicate
- func (f StringField) GtString(s string) Predicate
- func (f StringField) ILikeString(s string) Predicate
- func (f StringField) In(v interface{}) Predicate
- func (f StringField) IsNotNull() Predicate
- func (f StringField) IsNull() Predicate
- func (f StringField) Le(field StringField) Predicate
- func (f StringField) LeString(s string) Predicate
- func (f StringField) LikeString(s string) Predicate
- func (f StringField) Lt(field StringField) Predicate
- func (f StringField) LtString(s string) Predicate
- func (f StringField) Ne(field StringField) Predicate
- func (f StringField) NeString(s string) Predicate
- func (f StringField) NotILikeString(s string) Predicate
- func (f StringField) NotLikeString(s string) Predicate
- func (f StringField) NullsFirst() StringField
- func (f StringField) NullsLast() StringField
- func (f StringField) Set(value interface{}) FieldAssignment
- func (f StringField) SetString(s string) FieldAssignment
- func (f StringField) String() string
- type Subquery
- type Table
- type TableInfo
- type TimeField
- func (f TimeField) AppendSQLExclude(buf *strings.Builder, args *[]interface{}, excludedTableQualifiers []string)
- func (f TimeField) As(alias string) TimeField
- func (f TimeField) Asc() TimeField
- func (f TimeField) Between(start, end TimeField) Predicate
- func (f TimeField) BetweenSymmetricTime(start, end time.Time) Predicate
- func (f TimeField) BetweenTime(start, end time.Time) Predicate
- func (f TimeField) Desc() TimeField
- func (f TimeField) Eq(field TimeField) Predicate
- func (f TimeField) EqTime(t time.Time) Predicate
- func (f TimeField) Ge(field TimeField) Predicate
- func (f TimeField) GeTime(t time.Time) Predicate
- func (f TimeField) GetAlias() string
- func (f TimeField) GetName() string
- func (f TimeField) Gt(field TimeField) Predicate
- func (f TimeField) GtTime(t time.Time) Predicate
- func (f TimeField) IsNotNull() Predicate
- func (f TimeField) IsNull() Predicate
- func (f TimeField) Le(field TimeField) Predicate
- func (f TimeField) LeTime(t time.Time) Predicate
- func (f TimeField) Lt(field TimeField) Predicate
- func (f TimeField) LtTime(t time.Time) Predicate
- func (f TimeField) Ne(field TimeField) Predicate
- func (f TimeField) NeTime(t time.Time) Predicate
- func (f TimeField) NotBetween(start, end TimeField) Predicate
- func (f TimeField) NotBetweenSymmetricTime(start, end time.Time) Predicate
- func (f TimeField) NotBetweenTime(start, end time.Time) Predicate
- func (f TimeField) NullsFirst() TimeField
- func (f TimeField) NullsLast() TimeField
- func (f TimeField) Set(value interface{}) FieldAssignment
- func (f TimeField) SetTime(value time.Time) FieldAssignment
- func (f TimeField) String() string
- type UpdateQuery
- func (q UpdateQuery) AppendSQL(buf *strings.Builder, args *[]interface{})
- func (q UpdateQuery) CTE(name string, columns ...string) CTE
- func (q UpdateQuery) CustomJoin(joinType JoinType, table Table, predicates ...Predicate) UpdateQuery
- func (q UpdateQuery) Exec(db DB, flag ExecFlag) (rowsAffected int64, err error)
- func (q UpdateQuery) ExecContext(ctx context.Context, db DB, flag ExecFlag) (rowsAffected int64, err error)
- func (q UpdateQuery) Fetch(db DB) (err error)
- func (q UpdateQuery) FetchContext(ctx context.Context, db DB) (err error)
- func (q UpdateQuery) From(table Table) UpdateQuery
- func (q UpdateQuery) FullJoin(table Table, predicate Predicate, predicates ...Predicate) UpdateQuery
- func (q UpdateQuery) Join(table Table, predicate Predicate, predicates ...Predicate) UpdateQuery
- func (q UpdateQuery) LeftJoin(table Table, predicate Predicate, predicates ...Predicate) UpdateQuery
- func (q UpdateQuery) NestThis() Query
- func (q UpdateQuery) Returning(fields ...Field) UpdateQuery
- func (q UpdateQuery) ReturningOne() UpdateQuery
- func (q UpdateQuery) ReturningRowx(mapper func(*Row)) UpdateQuery
- func (q UpdateQuery) Returningx(mapper func(*Row), accumulator func()) UpdateQuery
- func (q UpdateQuery) RightJoin(table Table, predicate Predicate, predicates ...Predicate) UpdateQuery
- func (q UpdateQuery) Set(assignments ...Assignment) UpdateQuery
- func (q UpdateQuery) Setx(mapper func(*Column)) UpdateQuery
- func (q UpdateQuery) Subquery(alias string) Subquery
- func (q UpdateQuery) ToSQL() (string, []interface{})
- func (q UpdateQuery) Update(table BaseTable) UpdateQuery
- func (q UpdateQuery) Where(predicates ...Predicate) UpdateQuery
- func (q UpdateQuery) With(ctes ...CTE) UpdateQuery
- type VariadicPredicate
- type VariadicPredicateOperator
- type VariadicQuery
- type VariadicQueryOperator
- type Window
- type Windows
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func RowFloat64 ¶ added in v0.2.0
RowFloat64 returns the float64 value of a Field
func RowFloat64Valid ¶ added in v0.2.0
RowFloat64Valid returns the bool value indicating if the Field is non-NULL.
func RowInt64 ¶ added in v0.2.0
func RowInt64(r *Row, field NumberField) int64
RowInt64 returns the int64 value of the Field.
func RowInt64Valid ¶ added in v0.2.0
func RowInt64Valid(r *Row, field NumberField) bool
Int64Valid_ returns the bool value indicating if the Field is non-NULL.
func RowIntValid ¶ added in v0.2.0
RowIntValid returns the bool value indicating if the Field is non-NULL.
func RowNullFloat64 ¶ added in v0.2.0
func RowNullFloat64(r *Row, field Field) sql.NullFloat64
RowNullFloat64 returns the sql.NullFloat64 value of the Field.
func RowNullInt64 ¶ added in v0.2.0
RowNullInt64 returns the sql.NullInt64 value of the Field.
func RowNullString ¶ added in v0.2.0
func RowNullString(r *Row, field Field) sql.NullString
RowNullString returns the sql.NullString value of the Field.
func RowNullTime ¶ added in v0.2.0
RowNullTime returns the sql.NullTime value of the Field.
func RowStringValid ¶ added in v0.2.0
RowStringValid returns the bool value indicating if the Field is non-NULL.
func RowTimeValid ¶ added in v0.2.0
RowTimeValid returns a bool value indicating if the Field is non-NULL.
func SelectDistinctOn ¶
func SelectDistinctOn(distinctFields ...Field) func(...Field) SelectQuery
SelectDistinctOn creates a new SelectQuery.
Types ¶
type ArrayField ¶
type ArrayField struct {
// contains filtered or unexported fields
}
ArrayField either represents an ARRAY column, or a literal slice value.
func Array ¶
func Array(slice interface{}) ArrayField
Array returns a new ArrayField representing a literal string value.
func NewArrayField ¶
func NewArrayField(name string, table Table) ArrayField
NewArrayField returns a new ArrayField representing an array column.
func (ArrayField) AppendSQLExclude ¶
func (f ArrayField) AppendSQLExclude(buf *strings.Builder, args *[]interface{}, excludedTableQualifiers []string)
AppendSQLExclude marshals the ArrayField into a buffer and an args slice. It will not table qualify itself if its table qualifer appears in the excludedTableQualifiers list.
func (ArrayField) As ¶
func (f ArrayField) As(alias string) ArrayField
As returns a new ArrayField with the new field Alias i.e. 'field AS Alias'.
func (ArrayField) Asc ¶
func (f ArrayField) Asc() ArrayField
Asc returns a new ArrayField indicating that it should be ordered in ascending order i.e. 'ORDER BY field ASC'.
func (ArrayField) Concat ¶
func (f ArrayField) Concat(field ArrayField) Field
Concat concatenates the object ArrayField to the subject ArrayField.
func (ArrayField) ContainedBy ¶
func (f ArrayField) ContainedBy(field ArrayField) Predicate
Contains checks whether the subject ArrayField is contained by the object ArrayField.
func (ArrayField) Contains ¶
func (f ArrayField) Contains(field ArrayField) Predicate
Contains checks whether the subject ArrayField contains the object ArrayField.
func (ArrayField) Desc ¶
func (f ArrayField) Desc() ArrayField
Desc returns a new ArrayField indicating that it should be ordered in descending order i.e. 'ORDER BY field DESC'.
func (ArrayField) Eq ¶
func (f ArrayField) Eq(field ArrayField) Predicate
Eq returns an 'X = Y' Predicate. It only accepts ArrayField.
func (ArrayField) Ge ¶
func (f ArrayField) Ge(field ArrayField) Predicate
Ge returns an 'X >= Y' Predicate. It only accepts ArrayField.
func (ArrayField) GetAlias ¶
func (f ArrayField) GetAlias() string
GetAlias implements the Field interface. It returns the Alias of the ArrayField.
func (ArrayField) GetName ¶
func (f ArrayField) GetName() string
GetName implements the Field interface. It returns the Name of the ArrayField.
func (ArrayField) Gt ¶
func (f ArrayField) Gt(field ArrayField) Predicate
Gt returns an 'X > Y' Predicate. It only accepts ArrayField.
func (ArrayField) IsNotNull ¶
func (f ArrayField) IsNotNull() Predicate
IsNotNull returns an 'X IS NOT NULL' Predicate.
func (ArrayField) IsNull ¶
func (f ArrayField) IsNull() Predicate
IsNull returns an 'X IS NULL' Predicate.
func (ArrayField) Le ¶
func (f ArrayField) Le(field ArrayField) Predicate
Le returns an 'X <= Y' Predicate. It only accepts ArrayField.
func (ArrayField) Lt ¶
func (f ArrayField) Lt(field ArrayField) Predicate
Lt returns an 'X < Y' Predicate. It only accepts ArrayField.
func (ArrayField) Ne ¶
func (f ArrayField) Ne(field ArrayField) Predicate
Ne returns an 'X <> Y' Predicate. It only accepts ArrayField.
func (ArrayField) NullsFirst ¶
func (f ArrayField) NullsFirst() ArrayField
NullsFirst returns a new ArrayField indicating that it should be ordered with nulls first i.e. 'ORDER BY field NULLS FIRST'.
func (ArrayField) NullsLast ¶
func (f ArrayField) NullsLast() ArrayField
NullsLast returns a new ArrayField indicating that it should be ordered with nulls last i.e. 'ORDER BY field NULLS LAST'.
func (ArrayField) Overlaps ¶
func (f ArrayField) Overlaps(field ArrayField) Predicate
Overlaps checks whether the subject ArrayField and the object ArrayField have any values in common.
func (ArrayField) Set ¶
func (f ArrayField) Set(value ArrayField) FieldAssignment
SetArray returns a FieldAssignment associating the ArrayField to the value i.e. 'field = value'. It only accepts ArrayField.
func (ArrayField) String ¶
func (f ArrayField) String() string
String implements the fmt.Stringer interface. It returns the string representation of an ArrayField.
type Assignment ¶
type Assignments ¶
type Assignments []Assignment
Assignments is a list of Assignments, when translated to SQL it looks something like "SET field1 = value1, field2 = value2, etc...".
func (Assignments) AppendSQLExclude ¶
func (assignments Assignments) AppendSQLExclude(buf *strings.Builder, args *[]interface{}, excludedTableQualifiers []string)
AppendSQLExclude will write the Assignments into the buffer and args as described in the Assignments description.
type BaseQuery ¶
BaseQuery is a common query builder that can transform into a SelectQuery, InsertQuery, UpdateQuery or DeleteQuery depending on the method that you call on it.
func WithDefaultLog ¶
WithDefaultLog creates a new BaseQuery with the default logger and the LogFlag
func (BaseQuery) DeleteFrom ¶
func (q BaseQuery) DeleteFrom(table BaseTable) DeleteQuery
DeleteFrom transforms the BaseQuery into a DeleteQuery.
func (BaseQuery) From ¶
func (q BaseQuery) From(table Table) SelectQuery
From transforms the BaseQuery into a SelectQuery.
func (BaseQuery) InsertInto ¶
func (q BaseQuery) InsertInto(table BaseTable) InsertQuery
InsertInto transforms the BaseQuery into an InsertQuery.
func (BaseQuery) Select ¶
func (q BaseQuery) Select(fields ...Field) SelectQuery
Select transforms the BaseQuery into a SelectQuery.
func (BaseQuery) SelectAll ¶
func (q BaseQuery) SelectAll() SelectQuery
SelectAll transforms the BaseQuery into a SelectQuery.
func (BaseQuery) SelectCount ¶
func (q BaseQuery) SelectCount() SelectQuery
SelectCount transforms the BaseQuery into a SelectQuery.
func (BaseQuery) SelectDistinct ¶
func (q BaseQuery) SelectDistinct(fields ...Field) SelectQuery
SelectDistinct transforms the BaseQuery into a SelectQuery.
func (BaseQuery) SelectDistinctOn ¶
func (q BaseQuery) SelectDistinctOn(distinctFields ...Field) func(...Field) SelectQuery
SelectDistinctOn transforms the BaseQuery into a SelectQuery.
func (BaseQuery) SelectOne ¶
func (q BaseQuery) SelectOne() SelectQuery
SelectOne transforms the BaseQuery into a SelectQuery.
func (BaseQuery) SelectRowx ¶
func (q BaseQuery) SelectRowx(mapper func(*Row)) SelectQuery
SelectRowx transforms the BaseQuery into a SelectQuery.
func (BaseQuery) Selectx ¶
func (q BaseQuery) Selectx(mapper func(*Row), accumulator func()) SelectQuery
Selectx transforms the BaseQuery into a SelectQuery.
func (BaseQuery) Union ¶ added in v0.2.0
func (q BaseQuery) Union(queries ...Query) VariadicQuery
Union transforms the BaseQuery into a VariadicQuery.
func (BaseQuery) UnionAll ¶ added in v0.2.0
func (q BaseQuery) UnionAll(queries ...Query) VariadicQuery
UnionAll transforms the BaseQuery into a VariadicQuery.
func (BaseQuery) Update ¶
func (q BaseQuery) Update(table BaseTable) UpdateQuery
Update transforms the BaseQuery into an UpdateQuery.
func (BaseQuery) WithDefaultLog ¶
WithDefaultLog adds the default logger and the LogFlag to the BaseQuery.
type BaseTable ¶
type BaseTable interface { Table AssertBaseTable() }
BaseTable is an interface that specialises the Table interface. It covers only tables/views that exist in the database.
type BinaryField ¶
type BinaryField struct {
// contains filtered or unexported fields
}
BinaryField either represents a BYTEA column or a literal []byte value.
func Bytes ¶
func Bytes(b []byte) BinaryField
Bytes returns a new BinaryField representing a literal []byte value.
func NewBinaryField ¶
func NewBinaryField(name string, table Table) BinaryField
NewBinaryField returns a new BinaryField representing a BYTEA column.
func (BinaryField) AppendSQLExclude ¶
func (f BinaryField) AppendSQLExclude(buf *strings.Builder, args *[]interface{}, excludedTableQualifiers []string)
AppendSQLExclude marshals the BinaryField into a buffer and an args slice. It will not table qualify itself if its table qualifer appears in the excludedTableQualifiers list.
func (BinaryField) GetAlias ¶
func (f BinaryField) GetAlias() string
GetAlias implements the Field interface. It returns the Alias of the BinaryField.
func (BinaryField) GetName ¶
func (f BinaryField) GetName() string
GetName implements the Field interface. It returns the Name of the BinaryField.
func (BinaryField) IsNotNull ¶
func (f BinaryField) IsNotNull() Predicate
IsNotNull returns an 'X IS NOT NULL' Predicate.
func (BinaryField) IsNull ¶
func (f BinaryField) IsNull() Predicate
IsNull returns an 'X IS NULL' Predicate.
func (BinaryField) Set ¶
func (f BinaryField) Set(v interface{}) FieldAssignment
Set returns a FieldAssignment associating the BinaryField to the value i.e. 'field = value'.
func (BinaryField) SetBytes ¶
func (f BinaryField) SetBytes(b []byte) FieldAssignment
SetBytes returns a FieldAssignment associating the BinaryField to the int value i.e. 'field = value'.
type BooleanField ¶
type BooleanField struct {
// contains filtered or unexported fields
}
BooleanField either represents a boolean column or a literal bool value.
func Bool ¶
func Bool(b bool) BooleanField
Bool returns a new Boolean Field representing a literal bool value.
func NewBooleanField ¶
func NewBooleanField(name string, table Table) BooleanField
NewBooleanField returns a new BooleanField representing a boolean column.
func (BooleanField) AppendSQLExclude ¶
func (f BooleanField) AppendSQLExclude(buf *strings.Builder, args *[]interface{}, excludedTableQualifiers []string)
AppendSQLExclude marshals the BooleanField into a buffer and an args slice. It will not table qualify itself if its table qualifer appears in the excludedTableQualifiers list.
func (BooleanField) As ¶
func (f BooleanField) As(alias string) BooleanField
As returns a new BooleanField with the new field Alias i.e. 'field AS Alias'.
func (BooleanField) Asc ¶
func (f BooleanField) Asc() BooleanField
Asc returns a new BooleanField indicating that it should be ordered in ascending order i.e. 'ORDER BY field ASC'.
func (BooleanField) Desc ¶
func (f BooleanField) Desc() BooleanField
Desc returns a new BooleanField indicating that it should be ordered in descending order i.e. 'ORDER BY field DESC'.
func (BooleanField) Eq ¶
func (f BooleanField) Eq(field BooleanField) Predicate
Eq returns an 'X = Y' Predicate. It only accepts BooleanField.
func (BooleanField) GetAlias ¶
func (f BooleanField) GetAlias() string
GetAlias implements the Field interface. It returns the Alias of the BooleanField.
func (BooleanField) GetName ¶
func (f BooleanField) GetName() string
GetName implements the Field interface. It returns the Name of the BooleanField.
func (BooleanField) IsNotNull ¶
func (f BooleanField) IsNotNull() Predicate
IsNotNull returns an 'X IS NOT NULL' Predicate.
func (BooleanField) IsNull ¶
func (f BooleanField) IsNull() Predicate
IsNull returns an 'X IS NULL' Predicate.
func (BooleanField) Ne ¶
func (f BooleanField) Ne(field BooleanField) Predicate
Ne returns an 'X <> Y' Predicate. It only accepts BooleanField.
func (BooleanField) Not ¶
func (f BooleanField) Not() Predicate
Not implements the Predicate interface.
func (BooleanField) NullsFirst ¶
func (f BooleanField) NullsFirst() BooleanField
NullsFirst returns a new BooleanField indicating that it should be ordered with nulls first i.e. 'ORDER BY field NULLS FIRST'.
func (BooleanField) NullsLast ¶
func (f BooleanField) NullsLast() BooleanField
NullsLast returns a new BooleanField indicating that it should be ordered with nulls last i.e. 'ORDER BY field NULLS LAST'.
func (BooleanField) Set ¶
func (f BooleanField) Set(val interface{}) FieldAssignment
Set returns a FieldAssignment associating the BooleanField to the value i.e. 'field = value'.
func (BooleanField) SetBool ¶
func (f BooleanField) SetBool(val bool) FieldAssignment
SetBool returns a FieldAssignment associating the BooleanField to the bool value i.e. 'field = value'.
func (BooleanField) String ¶
func (f BooleanField) String() string
String implements the fmt.Stringer interface. It returns the string representation of a BooleanField.
type CTE ¶
type CTE map[string]CustomField
func RecursiveCTE ¶ added in v0.2.0
func (CTE) GetColumns ¶ added in v0.2.0
func (*CTE) Initial ¶ added in v0.2.0
func (cte *CTE) Initial(query Query) IntermediateCTE
func (CTE) IsRecursive ¶ added in v0.2.0
type Column ¶ added in v0.4.0
type Column struct {
// contains filtered or unexported fields
}
func (*Column) SetBool ¶ added in v0.4.0
func (col *Column) SetBool(field BooleanField, value bool)
func (*Column) SetFloat64 ¶ added in v0.4.0
func (col *Column) SetFloat64(field NumberField, value float64)
func (*Column) SetInt ¶ added in v0.4.0
func (col *Column) SetInt(field NumberField, value int)
func (*Column) SetInt64 ¶ added in v0.4.0
func (col *Column) SetInt64(field NumberField, value int64)
func (*Column) SetString ¶ added in v0.4.0
func (col *Column) SetString(field StringField, value string)
type CustomAssignment ¶
type CustomAssignment struct { Format string Values []interface{} }
func (CustomAssignment) AppendSQLExclude ¶
func (set CustomAssignment) AppendSQLExclude(buf *strings.Builder, args *[]interface{}, excludedTableQualifiers []string)
func (CustomAssignment) AssertAssignment ¶
func (set CustomAssignment) AssertAssignment()
type CustomField ¶
type CustomField struct { Alias string Format string Values []interface{} IsDesc *bool IsNullsFirst *bool }
CustomField is a Field that can render itself in an arbitrary way by calling expandValues on its Format and Values.
func Excluded ¶
func Excluded(field Field) CustomField
func Fieldf ¶
func Fieldf(format string, values ...interface{}) CustomField
Fieldf is a CustomField constructor.
func (CustomField) AppendSQLExclude ¶
func (f CustomField) AppendSQLExclude(buf *strings.Builder, args *[]interface{}, excludedTableQualifiers []string)
AppendSQL marshals the CustomField into an SQL query and args as described in the CustomField struct description.
func (CustomField) As ¶
func (f CustomField) As(alias string) CustomField
As returns a new CustomField with the new alias i.e. 'field AS Alias'.
func (CustomField) Asc ¶
func (f CustomField) Asc() CustomField
Asc returns a new CustomField indicating that it should be ordered in ascending order i.e. 'ORDER BY field ASC'.
func (CustomField) Desc ¶
func (f CustomField) Desc() CustomField
Desc returns a new CustomField indicating that it should be ordered in descending order i.e. 'ORDER BY field DESC'.
func (CustomField) Eq ¶
func (f CustomField) Eq(v interface{}) Predicate
Eq returns an 'X = Y' Predicate.
func (CustomField) Ge ¶
func (f CustomField) Ge(v interface{}) Predicate
Ge returns an 'X >= Y' Predicate.
func (CustomField) GetAlias ¶
func (f CustomField) GetAlias() string
GetAlias implements the Field interface. It returns the alias of thee CustomField.
func (CustomField) GetName ¶
func (f CustomField) GetName() string
GetName implements the Field interface. It returns the name of the CustomField.
func (CustomField) Gt ¶
func (f CustomField) Gt(v interface{}) Predicate
Gt returns an 'X > Y' Predicate.
func (CustomField) In ¶
func (f CustomField) In(v interface{}) Predicate
In returns an 'X IN (Y)' Predicate.
func (CustomField) IsNotNull ¶
func (f CustomField) IsNotNull() Predicate
IsNotNull returns an 'X IS NOT NULL' Predicate.
func (CustomField) IsNull ¶
func (f CustomField) IsNull() Predicate
IsNull returns an 'X IS NULL' Predicate.
func (CustomField) Le ¶
func (f CustomField) Le(v interface{}) Predicate
Le returns an 'X <= Y' Predicate.
func (CustomField) Lt ¶
func (f CustomField) Lt(v interface{}) Predicate
Lt returns an 'X < Y' Predicate.
func (CustomField) Ne ¶
func (f CustomField) Ne(v interface{}) Predicate
Ne returns an 'X <> Y' Predicate.
func (CustomField) NullsFirst ¶
func (f CustomField) NullsFirst() CustomField
NullsFirst returns a new CustomField indicating that it should be ordered with nulls first i.e. 'ORDER BY field NULLS FIRST'.
func (CustomField) NullsLast ¶
func (f CustomField) NullsLast() CustomField
NullsLast returns a new CustomField indicating that it should be ordered with nulls last i.e. 'ORDER BY field NULLS LAST'.
func (CustomField) String ¶
func (f CustomField) String() string
String implements the fmt.Stringer interface. It returns the string representation of a CustomField.
type CustomPredicate ¶
CustomPredicate is a Query that can render itself in an arbitrary way as defined by its Format string. Values are interpolated into the Format string as described in the (CustomPredicate).CustomSprintf function.
func Exists ¶
func Exists(query Query) CustomPredicate
func Predicatef ¶
func Predicatef(format string, values ...interface{}) CustomPredicate
func (CustomPredicate) AppendSQLExclude ¶
func (p CustomPredicate) AppendSQLExclude(buf *strings.Builder, args *[]interface{}, excludedTableQualifiers []string)
ToSQL marshals the CustomPredicate into an SQL query.
func (CustomPredicate) As ¶
func (p CustomPredicate) As(alias string) CustomPredicate
func (CustomPredicate) GetAlias ¶
func (p CustomPredicate) GetAlias() string
GetAlias implements the Field interface.
func (CustomPredicate) GetName ¶
func (p CustomPredicate) GetName() string
GetName implements the Field interface.
func (CustomPredicate) Not ¶
func (p CustomPredicate) Not() Predicate
Not implements the Predicate interface.
type DB ¶
type DB interface { Query(query string, args ...interface{}) (*sql.Rows, error) QueryContext(ctx context.Context, query string, args ...interface{}) (*sql.Rows, error) Exec(query string, args ...interface{}) (sql.Result, error) ExecContext(ctx context.Context, query string, args ...interface{}) (sql.Result, error) }
type DeleteQuery ¶
type DeleteQuery struct { // WITH CTEs []CTE // DELETE FROM FromTable BaseTable // USING UsingTable Table JoinTables JoinTables // WHERE WherePredicate VariadicPredicate // RETURNING ReturningFields Fields // DB DB DB RowMapper func(*Row) Accumulator func() // Logging Log Logger LogFlag LogFlag // contains filtered or unexported fields }
func DeleteFrom ¶
func DeleteFrom(table BaseTable) DeleteQuery
func (DeleteQuery) AppendSQL ¶
func (q DeleteQuery) AppendSQL(buf *strings.Builder, args *[]interface{})
func (DeleteQuery) CTE ¶ added in v0.2.0
func (q DeleteQuery) CTE(name string, columns ...string) CTE
func (DeleteQuery) CustomJoin ¶
func (q DeleteQuery) CustomJoin(joinType JoinType, table Table, predicates ...Predicate) DeleteQuery
func (DeleteQuery) DeleteFrom ¶
func (q DeleteQuery) DeleteFrom(table BaseTable) DeleteQuery
func (DeleteQuery) Exec ¶
func (q DeleteQuery) Exec(db DB, flag ExecFlag) (rowsAffected int64, err error)
func (DeleteQuery) ExecContext ¶
func (DeleteQuery) Fetch ¶
func (q DeleteQuery) Fetch(db DB) (err error)
func (DeleteQuery) FetchContext ¶
func (q DeleteQuery) FetchContext(ctx context.Context, db DB) (err error)
func (DeleteQuery) FullJoin ¶
func (q DeleteQuery) FullJoin(table Table, predicate Predicate, predicates ...Predicate) DeleteQuery
func (DeleteQuery) GetName ¶
func (q DeleteQuery) GetName() string
func (DeleteQuery) Join ¶
func (q DeleteQuery) Join(table Table, predicate Predicate, predicates ...Predicate) DeleteQuery
func (DeleteQuery) LeftJoin ¶
func (q DeleteQuery) LeftJoin(table Table, predicate Predicate, predicates ...Predicate) DeleteQuery
func (DeleteQuery) NestThis ¶
func (q DeleteQuery) NestThis() Query
func (DeleteQuery) Returning ¶
func (q DeleteQuery) Returning(fields ...Field) DeleteQuery
func (DeleteQuery) ReturningOne ¶
func (q DeleteQuery) ReturningOne() DeleteQuery
func (DeleteQuery) ReturningRowx ¶
func (q DeleteQuery) ReturningRowx(mapper func(*Row)) DeleteQuery
func (DeleteQuery) Returningx ¶
func (q DeleteQuery) Returningx(mapper func(*Row), accumulator func()) DeleteQuery
func (DeleteQuery) RightJoin ¶
func (q DeleteQuery) RightJoin(table Table, predicate Predicate, predicates ...Predicate) DeleteQuery
func (DeleteQuery) Subquery ¶ added in v0.2.0
func (q DeleteQuery) Subquery(alias string) Subquery
func (DeleteQuery) ToSQL ¶
func (q DeleteQuery) ToSQL() (string, []interface{})
func (DeleteQuery) Using ¶
func (q DeleteQuery) Using(table Table) DeleteQuery
func (DeleteQuery) Where ¶
func (q DeleteQuery) Where(predicates ...Predicate) DeleteQuery
func (DeleteQuery) With ¶
func (q DeleteQuery) With(ctes ...CTE) DeleteQuery
type EnumField ¶
type EnumField = StringField
EnumField is a type alias for StringField.
func NewEnumField ¶
NewEnumField returns an EnumField representing an enum column.
type ExitCode ¶
type ExitCode int
ExitCode represents a reason for terminating the rows.Next() loop.
type Field ¶
type Field interface { // Fields should respect the excludedTableQualifiers argument in ToSQL(). // E.g. if the field 'name' belongs to a table called 'users' and the // excludedTableQualifiers contains 'users', the field should present itself // as 'name' and not 'users.name'. i.e. any table qualifiers in the list // must be excluded. // // This is to play nice with certain clauses in the INSERT and UPDATE // queries that expressly forbid table qualified columns. AppendSQLExclude(buf *strings.Builder, args *[]interface{}, excludedTableQualifiers []string) GetAlias() string GetName() string }
Field is an interface that represents either a Table column or an SQL value.
type FieldAssignment ¶
type FieldAssignment struct { Field Field Value interface{} }
FieldAssignment represents a Field and Value set. Its usage appears in both the UPDATE and INSERT queries whenever values are assigned to columns e.g. 'field = value'.
func (FieldAssignment) AppendSQLExclude ¶
func (set FieldAssignment) AppendSQLExclude(buf *strings.Builder, args *[]interface{}, excludedTableQualifiers []string)
AppendSQLExclude will write the FieldAssignment into the buffer and args as described in the Assignments description.
func (FieldAssignment) AssertAssignment ¶
func (set FieldAssignment) AssertAssignment()
type FieldLiteral ¶
type FieldLiteral string
FieldLiteral is a Field where its underlying string is literally plugged into the SQL query.
func (FieldLiteral) AppendSQLExclude ¶
func (f FieldLiteral) AppendSQLExclude(buf *strings.Builder, _ *[]interface{}, _ []string)
ToSQL returns the underlying string of the FieldLiteral.
func (FieldLiteral) GetAlias ¶
func (f FieldLiteral) GetAlias() string
GetAlias implements the Field interface. It always returns an empty string because FieldLiterals do not have aliases.
func (FieldLiteral) GetName ¶
func (f FieldLiteral) GetName() string
GetName implements the Field interface. It returns the FieldLiteral's underlying string as the name.
type Fields ¶
type Fields []Field
Fields represents the "field1, field2, etc..." SQL construct.
func (Fields) AppendSQLExclude ¶
func (fs Fields) AppendSQLExclude(buf *strings.Builder, args *[]interface{}, excludedTableQualifiers []string)
AppendSQLExclude will write the a slice of Fields into the buffer and args as described in the Fields description. The list of table qualifiers to be excluded is propagated down to the individual Fields.
func (Fields) AppendSQLExcludeWithAlias ¶
func (fs Fields) AppendSQLExcludeWithAlias(buf *strings.Builder, args *[]interface{}, excludedTableQualifiers []string)
AppendSQLExcludeWithAlias is exactly like AppendSQLExclude, but appends each field (i.e. field1 AS alias1, field2 AS alias2, ...) with its alias if it has one.
type FunctionInfo ¶
func Functionf ¶
func Functionf(name string, args ...interface{}) *FunctionInfo
func (*FunctionInfo) AppendSQL ¶
func (f *FunctionInfo) AppendSQL(buf *strings.Builder, args *[]interface{})
AppendSQL adds the fully qualified function call into the buffer.
func (*FunctionInfo) AppendSQLExclude ¶
func (f *FunctionInfo) AppendSQLExclude(buf *strings.Builder, args *[]interface{}, excludedTableQualifiers []string)
AppendSQLExclude adds the fully qualified function call into the buffer.
func (*FunctionInfo) GetAlias ¶
func (f *FunctionInfo) GetAlias() string
GetAlias implements the Table interface. It returns the alias of the FunctionInfo.
func (*FunctionInfo) GetName ¶
func (f *FunctionInfo) GetName() string
GetName implements the Table interface. It returns the name of the FunctionInfo.
type InsertConflict ¶ added in v0.2.1
type InsertConflict struct {
// contains filtered or unexported fields
}
func (InsertConflict) DoNothing ¶ added in v0.2.1
func (c InsertConflict) DoNothing() InsertQuery
func (InsertConflict) DoUpdateSet ¶ added in v0.2.1
func (c InsertConflict) DoUpdateSet(assignments ...Assignment) InsertQuery
func (InsertConflict) Where ¶ added in v0.2.1
func (c InsertConflict) Where(predicates ...Predicate) InsertConflict
type InsertQuery ¶
type InsertQuery struct { // WITH CTEs []CTE // INSERT INTO IntoTable BaseTable InsertColumns Fields // VALUES RowValues RowValues // SELECT SelectQuery *SelectQuery // ON CONFLICT HandleConflict bool ConflictFields Fields ConflictPredicate VariadicPredicate ConflictConstraint string Resolution Assignments ResolutionPredicate VariadicPredicate // RETURNING ReturningFields Fields // DB DB DB ColumnMapper func(*Column) RowMapper func(*Row) Accumulator func() // Logging Log Logger LogFlag LogFlag // contains filtered or unexported fields }
func InsertInto ¶
func InsertInto(table BaseTable) InsertQuery
func (InsertQuery) AppendSQL ¶
func (q InsertQuery) AppendSQL(buf *strings.Builder, args *[]interface{})
func (InsertQuery) CTE ¶ added in v0.2.0
func (q InsertQuery) CTE(name string, columns ...string) CTE
func (InsertQuery) Columns ¶
func (q InsertQuery) Columns(fields ...Field) InsertQuery
func (InsertQuery) Exec ¶
func (q InsertQuery) Exec(db DB, flag ExecFlag) (rowsAffected int64, err error)
func (InsertQuery) ExecContext ¶
func (InsertQuery) Fetch ¶
func (q InsertQuery) Fetch(db DB) (err error)
func (InsertQuery) FetchContext ¶
func (q InsertQuery) FetchContext(ctx context.Context, db DB) (err error)
func (InsertQuery) InsertInto ¶
func (q InsertQuery) InsertInto(table BaseTable) InsertQuery
func (InsertQuery) InsertRow ¶
func (q InsertQuery) InsertRow(assignments ...FieldAssignment) InsertQuery
func (InsertQuery) NestThis ¶
func (q InsertQuery) NestThis() Query
func (InsertQuery) OnConflict ¶
func (q InsertQuery) OnConflict(fields ...Field) InsertConflict
func (InsertQuery) OnConflictOnConstraint ¶
func (q InsertQuery) OnConflictOnConstraint(name string) InsertConflict
func (InsertQuery) Returning ¶
func (q InsertQuery) Returning(fields ...Field) InsertQuery
func (InsertQuery) ReturningOne ¶
func (q InsertQuery) ReturningOne() InsertQuery
func (InsertQuery) ReturningRowx ¶
func (q InsertQuery) ReturningRowx(mapper func(*Row)) InsertQuery
func (InsertQuery) Returningx ¶
func (q InsertQuery) Returningx(mapper func(*Row), accumulator func()) InsertQuery
func (InsertQuery) Select ¶
func (q InsertQuery) Select(selectQuery SelectQuery) InsertQuery
func (InsertQuery) Subquery ¶ added in v0.2.0
func (q InsertQuery) Subquery(alias string) Subquery
func (InsertQuery) ToSQL ¶
func (q InsertQuery) ToSQL() (string, []interface{})
func (InsertQuery) Values ¶
func (q InsertQuery) Values(values ...interface{}) InsertQuery
func (InsertQuery) Valuesx ¶ added in v0.4.0
func (q InsertQuery) Valuesx(mapper func(*Column)) InsertQuery
func (InsertQuery) Where ¶
func (q InsertQuery) Where(predicates ...Predicate) InsertQuery
func (InsertQuery) With ¶
func (q InsertQuery) With(ctes ...CTE) InsertQuery
type IntermediateCTE ¶ added in v0.2.3
type IntermediateCTE map[string]CustomField
func (IntermediateCTE) Union ¶ added in v0.2.3
func (cte IntermediateCTE) Union(queries ...Query) CTE
func (IntermediateCTE) UnionAll ¶ added in v0.2.3
func (cte IntermediateCTE) UnionAll(queries ...Query) CTE
type JSONField ¶
type JSONField struct {
// contains filtered or unexported fields
}
JSONField either represents a JSON column or a literal value that can be marshalled into a JSON string.
func JSON ¶
JSON returns a new JSONField representing a literal JSONable value. It returns an error indicating if the value can be marshalled into JSON.
func MustJSON ¶
func MustJSON(val interface{}) JSONField
MustJSON is like JSON but it panics on error.
func NewJSONField ¶
NewJSONField returns a new JSONField representing a JSON column.
func (JSONField) AppendSQLExclude ¶
func (f JSONField) AppendSQLExclude(buf *strings.Builder, args *[]interface{}, excludedTableQualifiers []string)
AppendSQL marshals the JSONField into an SQL query and args as described in the JSONField internal struct comments.
func (JSONField) Asc ¶
Asc returns a new JSONField indicating that it should be ordered in ascending order i.e. 'ORDER BY field ASC'.
func (JSONField) Desc ¶
Desc returns a new JSONField indicating that it should be ordered in descending order i.e. 'ORDER BY field DESC'.
func (JSONField) GetAlias ¶
GetAlias implements the Field interface. It returns the Alias of the JSONField.
func (JSONField) GetName ¶
GetName implements the Field interface. It returns the Name of the JSONField.
func (JSONField) NullsFirst ¶
NullsFirst returns a new JSONField indicating that it should be ordered with nulls first i.e. 'ORDER BY field NULLS FIRST'.
func (JSONField) NullsLast ¶
NullsLast returns a new JSONField indicating that it should be ordered with nulls last i.e. 'ORDER BY field NULLS LAST'.
func (JSONField) Set ¶
func (f JSONField) Set(value interface{}) FieldAssignment
Set returns a FieldAssignment associating the JSONField to the value i.e. 'field = value'.
func (JSONField) SetJSON ¶
func (f JSONField) SetJSON(value interface{}) FieldAssignment
SetJSON returns a FieldAssignment associating the JSONField to the JSONable value i.e. 'field = value'. Internally it uses MustJSON, which means it will panic if the value cannot be marshalled into JSON.
type JoinTable ¶
type JoinTable struct { JoinType JoinType Table Table OnPredicates VariadicPredicate }
JoinTable represents an SQL join.
func CustomJoin ¶
CustomJoin constructs a new JoinTable. Meant to be used if you want to do a custom join like CROSS JOIN, NATURAL JOIN, LEFT JOIN LATERAL etc.
type JoinTables ¶
type JoinTables []JoinTable
JoinTables is a list of JoinTables.
func (JoinTables) AppendSQL ¶
func (joins JoinTables) AppendSQL(buf *strings.Builder, args *[]interface{})
AppendSQL will write the JOIN clause into the buffer and args. If there are no JoinTables it simply writes nothing into the buffer. It returns a flag indicating whether anything was written into the buffer.
type NumberField ¶
type NumberField struct {
// contains filtered or unexported fields
}
NumberField either represents a number column, a number expression or a literal number value.
func AvgOver ¶
func AvgOver(field interface{}, window Window) NumberField
AvgOver represents the AVG() OVER window function.
func CountOver ¶
func CountOver(window Window) NumberField
CountOver represents the COUNT(*) OVER window function.
func Float64 ¶
func Float64(num float64) NumberField
Float64 returns a new NumberField representing a literal float64 value.
func Int ¶
func Int(num int) NumberField
Int returns a new NumberField representing a literal int value.
func Int64 ¶
func Int64(num int64) NumberField
Int64 returns a new NumberField representing a literal int64 value.
func MaxOver ¶
func MaxOver(field interface{}, window Window) NumberField
MaxOver represents the MAX() OVER window function.
func MinOver ¶
func MinOver(field interface{}, window Window) NumberField
MinOver represents the MIN() OVER window function.
func NewNumberField ¶
func NewNumberField(name string, table Table) NumberField
NewNumberField returns a new NumberField representing a number TableInfo column.
func NumberFieldf ¶
func NumberFieldf(format string, values ...interface{}) NumberField
func SumOver ¶
func SumOver(field interface{}, window Window) NumberField
SumOver represents the SUM() OVER window function.
func (NumberField) AppendSQLExclude ¶
func (f NumberField) AppendSQLExclude(buf *strings.Builder, args *[]interface{}, excludedTableQualifiers []string)
AppendSQLExclude marshals the NumberField into an SQL query and args as described in the NumberField internal struct comments.
func (NumberField) As ¶
func (f NumberField) As(alias string) NumberField
As returns a new NumberField with the new field Alias i.e. 'field AS Alias'.
func (NumberField) Asc ¶
func (f NumberField) Asc() NumberField
Asc returns a new NumberField indicating that it should be ordered in ascending order i.e. 'ORDER BY field ASC'.
func (NumberField) Desc ¶
func (f NumberField) Desc() NumberField
Desc returns a new NumberField indicating that it should be ordered in descending order i.e. 'ORDER BY field DESC'.
func (NumberField) Eq ¶
func (f NumberField) Eq(field NumberField) Predicate
Eq returns an 'X = Y' Predicate. It only accepts NumberField.
func (NumberField) EqFloat64 ¶
func (f NumberField) EqFloat64(num float64) Predicate
EqFloat64 returns an 'X = Y' Predicate. It only accepts float64.
func (NumberField) EqInt ¶
func (f NumberField) EqInt(num int) Predicate
EqInt returns an 'X = Y' Predicate. It only accepts int.
func (NumberField) Ge ¶
func (f NumberField) Ge(field NumberField) Predicate
Ge returns an 'X >= Y' Predicate. It only accepts NumberField.
func (NumberField) GeFloat64 ¶
func (f NumberField) GeFloat64(num float64) Predicate
GeFloat64 returns an 'X >= Y' Predicate. It only accepts float64.
func (NumberField) GeInt ¶
func (f NumberField) GeInt(num int) Predicate
GeInt returns an 'X >= Y' Predicate. It only accepts int.
func (NumberField) GetAlias ¶
func (f NumberField) GetAlias() string
GetAlias implements the Field interface. It returns the Alias of the NumberField.
func (NumberField) GetName ¶
func (f NumberField) GetName() string
GetName implements the Field interface. It returns the Name of the NumberField.
func (NumberField) Gt ¶
func (f NumberField) Gt(field NumberField) Predicate
Gt returns an 'X > Y' Predicate. It only accepts NumberField.
func (NumberField) GtFloat64 ¶
func (f NumberField) GtFloat64(num float64) Predicate
GtFloat64 returns an 'X > Y' Predicate. It only accepts float64.
func (NumberField) GtInt ¶
func (f NumberField) GtInt(num int) Predicate
GtInt returns an 'X > Y' Predicate. It only accepts int.
func (NumberField) In ¶
func (f NumberField) In(v interface{}) Predicate
In returns an 'X IN (Y)' Predicate.
func (NumberField) IsNotNull ¶
func (f NumberField) IsNotNull() Predicate
IsNotNull returns an 'X IS NOT NULL' Predicate.
func (NumberField) IsNull ¶
func (f NumberField) IsNull() Predicate
IsNull returns an 'X IS NULL' Predicate.
func (NumberField) Le ¶
func (f NumberField) Le(field NumberField) Predicate
Le returns an 'X <= Y' Predicate. It only accepts NumberField.
func (NumberField) LeFloat64 ¶
func (f NumberField) LeFloat64(num float64) Predicate
LeFloat64 returns an 'X <= Y' Predicate. It only accepts float64.
func (NumberField) LeInt ¶
func (f NumberField) LeInt(num int) Predicate
LeInt returns an 'X <= Y' Predicate. It only accepts int.
func (NumberField) Lt ¶
func (f NumberField) Lt(field NumberField) Predicate
Lt returns an 'X < Y' Predicate. It only accepts NumberField.
func (NumberField) LtFloat64 ¶
func (f NumberField) LtFloat64(num float64) Predicate
LtFloat64 returns an 'X < Y' Predicate. It only accepts float64.
func (NumberField) LtInt ¶
func (f NumberField) LtInt(num int) Predicate
LtInt returns an 'X < Y' Predicate. It only accepts int.
func (NumberField) Ne ¶
func (f NumberField) Ne(field NumberField) Predicate
Ne returns an 'X <> Y' Predicate. It only accepts NumberField.
func (NumberField) NeFloat64 ¶
func (f NumberField) NeFloat64(num float64) Predicate
NeFloat64 returns an 'X <> Y' Predicate. It only accepts float64.
func (NumberField) NeInt ¶
func (f NumberField) NeInt(num int) Predicate
NeInt returns an 'X <> Y' Predicate. It only accepts int.
func (NumberField) NullsFirst ¶
func (f NumberField) NullsFirst() NumberField
NullsFirst returns a new NumberField indicating that it should be ordered with nulls first i.e. 'ORDER BY field NULLS FIRST'.
func (NumberField) NullsLast ¶
func (f NumberField) NullsLast() NumberField
NullsLast returns a new NumberField indicating that it should be ordered with nulls last i.e. 'ORDER BY field NULLS LAST'.
func (NumberField) Set ¶
func (f NumberField) Set(val interface{}) FieldAssignment
Set returns a FieldAssignment associating the NumberField to the value i.e. 'field = value'.
func (NumberField) SetFloat64 ¶
func (f NumberField) SetFloat64(num float64) FieldAssignment
SetFloat64 returns a FieldAssignment associating the NumberField to the float64 value i.e. 'field = value'.
func (NumberField) SetInt ¶
func (f NumberField) SetInt(num int) FieldAssignment
SetInt returns a FieldAssignment associating the NumberField to the int value i.e. 'field = value'.
func (NumberField) SetInt64 ¶
func (f NumberField) SetInt64(num int64) FieldAssignment
SetInt64 returns a FieldAssignment associating the NumberField to the int64 value i.e. 'field = value'.
func (NumberField) String ¶
func (f NumberField) String() string
String implements the fmt.Stringer interface. It returns the string representation of a NumberField.
type PredicateCase ¶
type PredicateCase struct { Condition Predicate Result interface{} }
PredicateCase represents a Predicate and the Result if the Predicate is true.
type PredicateCases ¶
type PredicateCases struct { Alias string Cases []PredicateCase Fallback interface{} }
PredicateCases is the general form of the CASE expression.
func CaseWhen ¶
func CaseWhen(predicate Predicate, result interface{}) PredicateCases
CaseWhen creates a new PredicateCases i.e. CASE WHEN X THEN Y.
func (PredicateCases) AppendSQLExclude ¶
func (f PredicateCases) AppendSQLExclude(buf *strings.Builder, args *[]interface{}, excludedTableQualifiers []string)
AppendSQLExclude marshals the PredicateCases into a buffer and an args slice. It propagates the excludedTableQualifiers down to its child elements.
func (PredicateCases) As ¶
func (f PredicateCases) As(alias string) PredicateCases
As aliases the PredicateCases.
func (PredicateCases) Else ¶
func (f PredicateCases) Else(fallback interface{}) PredicateCases
Else adds the fallback value for the PredicateCases i.e. ELSE X.
func (PredicateCases) GetAlias ¶
func (f PredicateCases) GetAlias() string
GetAlias returns the alias of the PredicateCases.
func (PredicateCases) GetName ¶
func (f PredicateCases) GetName() string
GetName returns the name of the PredicateCases, which is always an empty string.
func (PredicateCases) When ¶
func (f PredicateCases) When(predicate Predicate, result interface{}) PredicateCases
When adds a new PredicateCase to the PredicateCases i.e. WHEN X THEN Y.
type Query ¶
type Query interface { AppendSQL(buf *strings.Builder, args *[]interface{}) // When NestThis is called on a query, it signals to the query that it is // being nested as part of a larger query. The nested query should: // - hold off rebinding question mark ?, ? to dollar $1, $2 placeholders because the parent query will do it // - hold off logging anything because the parent query will do it NestThis() Query ToSQL() (string, []interface{}) }
Query is an interface that specialises the Table interface. It covers only queries like SELECT/INSERT/UPDATE/DELETE.
type Row ¶
type Row struct {
// contains filtered or unexported fields
}
Row represents the state of a row after a call to rows.Next().
func (*Row) Bool ¶
Bool returns the bool value of the Predicate. BooleanFields are considered predicates, so you can use them here.
func (*Row) BoolValid ¶
BoolValid returns the bool value indicating if the Predicate is non-NULL. BooleanFields are considered Predicates, so you can use them here.
func (*Row) Float64 ¶
func (r *Row) Float64(field NumberField) float64
Float64 returns the float64 value of the NumberField.
func (*Row) Float64Valid ¶
func (r *Row) Float64Valid(field NumberField) bool
Float64Valid returns the bool value indicating if the NumberField is non-NULL.
func (*Row) Int ¶
func (r *Row) Int(field NumberField) int
Int returns the int value of the NumberField.
func (*Row) Int64 ¶
func (r *Row) Int64(field NumberField) int64
Int64 returns the int64 value of the NumberField.
func (*Row) Int64Valid ¶
func (r *Row) Int64Valid(field NumberField) bool
Int64Valid returns the bool value indicating if the NumberField is non-NULL.
func (*Row) IntValid ¶
func (r *Row) IntValid(field NumberField) bool
IntValid returns the bool value indicating if the NumberField is non-NULL.
func (*Row) NullFloat64 ¶
func (r *Row) NullFloat64(field NumberField) sql.NullFloat64
NullFloat64 returns the sql.NullFloat64 value of the NumberField.
func (*Row) NullInt64 ¶
func (r *Row) NullInt64(field NumberField) sql.NullInt64
NullInt64 returns the sql.NullInt64 value of the NumberField.
func (*Row) NullString ¶
func (r *Row) NullString(field StringField) sql.NullString
NullString returns the sql.NullString value of the StringField.
func (*Row) ScanArray ¶
ScanArray accepts a pointer to a slice and scans a postgres array into it. Only []bool, []float64, []int64 or []string slices are supported.
func (*Row) String ¶
func (r *Row) String(field StringField) string
String returns the string value of the StringField.
func (*Row) StringValid ¶
func (r *Row) StringValid(field StringField) bool
StringValid returns the bool value indicating if the StringField is non-NULL.
type RowValue ¶
type RowValue []interface{}
func (RowValue) AppendSQLExclude ¶
func (RowValue) In ¶
func (r RowValue) In(v interface{}) CustomPredicate
func (RowValue) Set ¶
func (r RowValue) Set(v interface{}) CustomAssignment
type RowValues ¶
type RowValues []RowValue
RowValues represents a list of RowValues (a, b, c...), (d, e, f...), (g, h, i...)
type SelectQuery ¶
type SelectQuery struct { // WITH CTEs []CTE // SELECT SelectType SelectType SelectFields Fields DistinctOn Fields // FROM FromTable Table JoinTables JoinTables // WHERE WherePredicate VariadicPredicate // GROUP BY GroupByFields Fields // HAVING HavingPredicate VariadicPredicate // WINDOW Windows Windows // ORDER BY OrderByFields Fields // LIMIT LimitValue *int64 // OFFSET OffsetValue *int64 // DB DB DB RowMapper func(*Row) Accumulator func() // Logging Log Logger LogFlag LogFlag // contains filtered or unexported fields }
SelectQuery represents a SELECT query.
func SelectDistinct ¶
func SelectDistinct(fields ...Field) SelectQuery
SelectDistinct creates a new SelectQuery.
func SelectRowx ¶
func SelectRowx(mapper func(*Row)) SelectQuery
SelectRowx creates a new SelectQuery.
func Selectx ¶
func Selectx(mapper func(*Row), accumulator func()) SelectQuery
Selectx creates a new SelectQuery.
func (SelectQuery) AppendSQL ¶
func (q SelectQuery) AppendSQL(buf *strings.Builder, args *[]interface{})
AppendSQL marshals the SelectQuery into a buffer and args slice.
func (SelectQuery) CTE ¶ added in v0.2.0
func (q SelectQuery) CTE(name string, columns ...string) CTE
func (SelectQuery) CustomJoin ¶
func (q SelectQuery) CustomJoin(joinType JoinType, table Table, predicates ...Predicate) SelectQuery
CustomJoin custom joins a table to the SelectQuery. The join type can be specified with a string, e.g. "CROSS JOIN".
func (SelectQuery) Exec ¶
func (q SelectQuery) Exec(db DB, flag ExecFlag) (rowsAffected int64, err error)
Exec will execute the SelectQuery with the given DB. It will only compute the rowsAffected if the ErowsAffected Execflag is passed to it.
func (SelectQuery) ExecContext ¶
func (q SelectQuery) ExecContext(ctx context.Context, db DB, flag ExecFlag) (rowsAffected int64, err error)
ExecContext will execute the SelectQuery with the given DB and context. It will only compute the rowsAffected if the ErowsAffected Execflag is passed to it.
func (SelectQuery) Fetch ¶
func (q SelectQuery) Fetch(db DB) (err error)
Fetch will run SelectQuery with the given DB. It then maps the results based on the mapper function (and optionally runs the accumulator function).
func (SelectQuery) FetchContext ¶
func (q SelectQuery) FetchContext(ctx context.Context, db DB) (err error)
FetchContext will run SelectQuery with the given DB and context. It then maps the results based on the mapper function (and optionally runs the accumulator function).
func (SelectQuery) From ¶
func (q SelectQuery) From(table Table) SelectQuery
From sets the table in the SelectQuery.
func (SelectQuery) FullJoin ¶
func (q SelectQuery) FullJoin(table Table, predicate Predicate, predicates ...Predicate) SelectQuery
FullJoin full joins a table to the SelectQuery based on the predicates.
func (SelectQuery) GroupBy ¶
func (q SelectQuery) GroupBy(fields ...Field) SelectQuery
GroupBy appends the fields to the GROUP BY clause in the SelectQuery.
func (SelectQuery) Having ¶
func (q SelectQuery) Having(predicates ...Predicate) SelectQuery
Having appends the predicates to the HAVING clause in the SelectQuery.
func (SelectQuery) Join ¶
func (q SelectQuery) Join(table Table, predicate Predicate, predicates ...Predicate) SelectQuery
Join joins a new table to the SelectQuery based on the predicates.
func (SelectQuery) LeftJoin ¶
func (q SelectQuery) LeftJoin(table Table, predicate Predicate, predicates ...Predicate) SelectQuery
LeftJoin left joins a new table to the SelectQuery based on the predicates.
func (SelectQuery) Limit ¶
func (q SelectQuery) Limit(limit int) SelectQuery
Limit sets the limit in the SelectQuery.
func (SelectQuery) NestThis ¶
func (q SelectQuery) NestThis() Query
NestThis indicates to the SelectQuery that it is nested.
func (SelectQuery) Offset ¶
func (q SelectQuery) Offset(offset int) SelectQuery
Offset sets the offset in the SelectQuery.
func (SelectQuery) OrderBy ¶
func (q SelectQuery) OrderBy(fields ...Field) SelectQuery
OrderBy appends the fields to the ORDER BY clause in the SelectQuery.
func (SelectQuery) RightJoin ¶
func (q SelectQuery) RightJoin(table Table, predicate Predicate, predicates ...Predicate) SelectQuery
RightJoin right joins a new table to the SelectQuery based on the predicates.
func (SelectQuery) Select ¶
func (q SelectQuery) Select(fields ...Field) SelectQuery
Select adds the fields to the SelectFields in the SelectQuery.
func (SelectQuery) SelectAll ¶
func (q SelectQuery) SelectAll() SelectQuery
SelectAll sets the SELECT clause to SELECT *.
func (SelectQuery) SelectCount ¶
func (q SelectQuery) SelectCount() SelectQuery
SelectCount sets the SELECT clause to SELECT COUNT(*).
func (SelectQuery) SelectDistinct ¶
func (q SelectQuery) SelectDistinct(fields ...Field) SelectQuery
SelectDistinct adds the fields to the SelectFields in the SelectQuery.
func (SelectQuery) SelectDistinctOn ¶
func (q SelectQuery) SelectDistinctOn(distinctFields ...Field) func(...Field) SelectQuery
SelectDistinctOn adds the distinctFields to the DistinctOn fields and the fields to the SelectFields in the SelectQuery.
func (SelectQuery) SelectOne ¶
func (q SelectQuery) SelectOne() SelectQuery
SelectOne sets the SELECT clause to SELECT 1.
func (SelectQuery) SelectRowx ¶
func (q SelectQuery) SelectRowx(mapper func(*Row)) SelectQuery
SelectRowx sets the mapper function in the SelectQuery.
func (SelectQuery) Selectx ¶
func (q SelectQuery) Selectx(mapper func(*Row), accumulator func()) SelectQuery
Selectx sets the mapper function and accumulator function in the SelectQuery.
func (SelectQuery) Subquery ¶ added in v0.2.0
func (q SelectQuery) Subquery(alias string) Subquery
func (SelectQuery) ToSQL ¶
func (q SelectQuery) ToSQL() (string, []interface{})
ToSQL marshals the SelectQuery into a query string and args slice.
func (SelectQuery) Where ¶
func (q SelectQuery) Where(predicates ...Predicate) SelectQuery
Where appends the predicates to the WHERE clause in the SelectQuery.
func (SelectQuery) Window ¶
func (q SelectQuery) Window(windows ...Window) SelectQuery
Window appends the windows to the WINDOW clause in the SelectQuery.
func (SelectQuery) With ¶
func (q SelectQuery) With(ctes ...CTE) SelectQuery
With appends a list of CTEs into the SelectQuery.
type SelectType ¶
type SelectType string
SelectType represents the various SQL selects.
const ( SelectTypeDefault SelectType = "SELECT" SelectTypeDistinct SelectType = "SELECT DISTINCT" SelectTypeDistinctOn SelectType = "SELECT DISTINCT ON" )
SelectTypes
type SimpleCase ¶
type SimpleCase struct { Value interface{} Result interface{} }
SimpleCase represents a Value to be compared against and the Result if it matches.
type SimpleCases ¶
type SimpleCases struct { Alias string Expression interface{} Cases []SimpleCase Fallback interface{} }
SimpleCases is the simple form of the CASE expression.
func (SimpleCases) AppendSQLExclude ¶
func (f SimpleCases) AppendSQLExclude(buf *strings.Builder, args *[]interface{}, excludedTableQualifiers []string)
AppendSQLExclude marshals the SimpleCases into a buffer and an args slice. It propagates the excludedTableQualifiers down to its child elements.
func (SimpleCases) As ¶
func (f SimpleCases) As(alias string) SimpleCases
As aliases the SimpleCases.
func (SimpleCases) Else ¶
func (f SimpleCases) Else(field Field) SimpleCases
Else adds the fallback value for the SimpleCases i.e. ELSE X.
func (SimpleCases) GetAlias ¶
func (f SimpleCases) GetAlias() string
GetAlias returns the alias of the SimpleCases.
func (SimpleCases) GetName ¶
func (f SimpleCases) GetName() string
GetName returns the name of the simple cases, which is always an empty string.
func (SimpleCases) When ¶
func (f SimpleCases) When(field Field, result Field) SimpleCases
When adds a new SimpleCase to the SimpleCases i.e. WHEN X THEN Y.
type StringField ¶
type StringField struct {
// contains filtered or unexported fields
}
StringField either represents a string column or a literal string value.
func NewStringField ¶
func NewStringField(name string, table Table) StringField
NewStringField returns a new StringField representing a boolean column.
func String ¶
func String(s string) StringField
String returns a new StringField representing a literal string value.
func (StringField) AppendSQLExclude ¶
func (f StringField) AppendSQLExclude(buf *strings.Builder, args *[]interface{}, excludedTableQualifiers []string)
AppendSQLExclude marshals the StringField into an SQL query and args as described in the StringField internal struct comments.
func (StringField) As ¶
func (f StringField) As(alias string) StringField
As returns a new StringField with the new field Alias i.e. 'field AS Alias'.
func (StringField) Asc ¶
func (f StringField) Asc() StringField
Asc returns a new StringField indicating that it should be ordered in ascending order i.e. 'ORDER BY field ASC'.
func (StringField) Desc ¶
func (f StringField) Desc() StringField
Desc returns a new StringField indicating that it should be ordered in descending order i.e. 'ORDER BY field DESC'.
func (StringField) Eq ¶
func (f StringField) Eq(field StringField) Predicate
Eq returns an 'X = Y' Predicate. It only accepts StringField.
func (StringField) EqString ¶
func (f StringField) EqString(s string) Predicate
EqString returns an 'X = Y' Predicate. It only accepts string.
func (StringField) Ge ¶
func (f StringField) Ge(field StringField) Predicate
Ge returns an 'X >= Y' Predicate. It only accepts StringField.
func (StringField) GeString ¶
func (f StringField) GeString(s string) Predicate
GeString returns an 'X >= Y' Predicate. It only accepts string.
func (StringField) GetAlias ¶
func (f StringField) GetAlias() string
GetAlias implements the Field interface. It returns the Alias of the StringField.
func (StringField) GetName ¶
func (f StringField) GetName() string
GetName implements the Field interface. It returns the Name of the StringField.
func (StringField) Gt ¶
func (f StringField) Gt(field StringField) Predicate
Gt returns an 'X > Y' Predicate. It only accepts StringField.
func (StringField) GtString ¶
func (f StringField) GtString(s string) Predicate
GtString returns an 'X > Y' Predicate. It only accepts string.
func (StringField) ILikeString ¶
func (f StringField) ILikeString(s string) Predicate
LikeString returns an 'A ILIKE B' Predicate. It only accepts string.
func (StringField) In ¶
func (f StringField) In(v interface{}) Predicate
In returns an 'X IN (Y)' Predicate.
func (StringField) IsNotNull ¶
func (f StringField) IsNotNull() Predicate
IsNotNull returns an 'X IS NOT NULL' Predicate.
func (StringField) IsNull ¶
func (f StringField) IsNull() Predicate
IsNull returns an 'X IS NULL' Predicate.
func (StringField) Le ¶
func (f StringField) Le(field StringField) Predicate
Le returns an 'X <= Y' Predicate. It only accepts StringField.
func (StringField) LeString ¶
func (f StringField) LeString(s string) Predicate
LeString returns an 'X <= Y' Predicate. It only accepts string.
func (StringField) LikeString ¶
func (f StringField) LikeString(s string) Predicate
LikeString returns an 'A LIKE B' Predicate. It only accepts string.
func (StringField) Lt ¶
func (f StringField) Lt(field StringField) Predicate
Lt returns an 'X < Y' Predicate. It only accepts StringField.
func (StringField) LtString ¶
func (f StringField) LtString(s string) Predicate
LtString returns an 'X < Y' Predicate. It only accepts string.
func (StringField) Ne ¶
func (f StringField) Ne(field StringField) Predicate
Ne returns an 'X <> Y' Predicate. It only accepts StringField.
func (StringField) NeString ¶
func (f StringField) NeString(s string) Predicate
NeString returns an 'X <> Y' Predicate. It only accepts string.
func (StringField) NotILikeString ¶
func (f StringField) NotILikeString(s string) Predicate
NotLikeString returns an 'A NOT ILIKE B' Predicate. It only accepts string.
func (StringField) NotLikeString ¶
func (f StringField) NotLikeString(s string) Predicate
NotLikeString returns an 'A NOT LIKE B' Predicate. It only accepts string.
func (StringField) NullsFirst ¶
func (f StringField) NullsFirst() StringField
NullsFirst returns a new StringField indicating that it should be ordered with nulls first i.e. 'ORDER BY field NULLS FIRST'.
func (StringField) NullsLast ¶
func (f StringField) NullsLast() StringField
NullsLast returns a new StringField indicating that it should be ordered with nulls last i.e. 'ORDER BY field NULLS LAST'.
func (StringField) Set ¶
func (f StringField) Set(value interface{}) FieldAssignment
Set returns a FieldAssignment associating the StringField to the value i.e. 'field = value'.
func (StringField) SetString ¶
func (f StringField) SetString(s string) FieldAssignment
SetString returns a FieldAssignment associating the StringField to the string value i.e. 'field = value'.
func (StringField) String ¶
func (f StringField) String() string
String implements the fmt.Stringer interface. It returns the string representation of a StringField.
type Subquery ¶ added in v0.2.0
type Subquery map[string]CustomField
type Table ¶
type Table interface { AppendSQL(buf *strings.Builder, args *[]interface{}) GetAlias() string GetName() string // Table name must exclude the schema (if any) }
Table is an interface representing anything that you can SELECT FROM or JOIN.
type TableInfo ¶
TableInfo is struct that implements the Table interface, containing all the information needed to call itself a Table. It is meant to be embedded in arbitrary structs to also transform them into valid Tables.
func (*TableInfo) AssertBaseTable ¶
func (tbl *TableInfo) AssertBaseTable()
AssertBaseTable implements the BaseTable interface.
type TimeField ¶
type TimeField struct {
// contains filtered or unexported fields
}
TimeField either represents a time column or a literal time.Time value.
func NewTimeField ¶
NewTimeField returns a new TimeField representing a time column.
func (TimeField) AppendSQLExclude ¶
func (f TimeField) AppendSQLExclude(buf *strings.Builder, args *[]interface{}, excludedTableQualifiers []string)
AppendSQLExclude marshals the TimeField into an SQL query and args as described in the TimeField internal struct comments.
func (TimeField) Asc ¶
Asc returns a new TimeField indicating that it should be ordered in ascending order i.e. 'ORDER BY field ASC'.
func (TimeField) Between ¶
Between returns an 'X BETWEEN Y AND Z' Predicate. It only accepts TimeField.
func (TimeField) BetweenSymmetricTime ¶
BetweenSymmetricTime returns an 'X BETWEEN SYMMETRIC Y AND Z' Predicate. It only accepts time.Time.
func (TimeField) BetweenTime ¶
BetweenTime returns an 'X BETWEEN Y AND Z' Predicate. It only accepts time.Time.
func (TimeField) Desc ¶
Desc returns a new TimeField indicating that it should be ordered in descending order i.e. 'ORDER BY field DESC'.
func (TimeField) GetAlias ¶
GetAlias implements the Field interface. It returns the Alias of the TimeField.
func (TimeField) GetName ¶
GetName implements the Field interface. It returns the Name of the TimeField.
func (TimeField) NotBetween ¶
NotBetween returns an 'X NOT BETWEEN Y AND Z' Predicate. It only accepts TimeField.
func (TimeField) NotBetweenSymmetricTime ¶
NotBetweenSymmetricTime returns an 'X NOT BETWEEN Y AND Z' Predicate. It only accepts time.Time.
func (TimeField) NotBetweenTime ¶
NotBetweenTime returns an 'X NOT BETWEEN Y AND Z' Predicate. It only accepts time.Time.
func (TimeField) NullsFirst ¶
NullsFirst returns a new TimeField indicating that it should be ordered with nulls first i.e. 'ORDER BY field NULLS FIRST'.
func (TimeField) NullsLast ¶
NullsLast returns a new TimeField indicating that it should be ordered with nulls last i.e. 'ORDER BY field NULLS LAST'.
func (TimeField) Set ¶
func (f TimeField) Set(value interface{}) FieldAssignment
Set returns a FieldAssignment associating the TimeField to the value i.e. 'field = value'.
type UpdateQuery ¶
type UpdateQuery struct { // WITH CTEs []CTE // UPDATE UpdateTable BaseTable // SET Assignments Assignments // FROM FromTable Table JoinTables JoinTables // WHERE WherePredicate VariadicPredicate // RETURNING ReturningFields Fields // DB DB DB ColumnMapper func(*Column) RowMapper func(*Row) Accumulator func() // Logging Log Logger LogFlag LogFlag // contains filtered or unexported fields }
func Update ¶
func Update(table BaseTable) UpdateQuery
func (UpdateQuery) AppendSQL ¶
func (q UpdateQuery) AppendSQL(buf *strings.Builder, args *[]interface{})
func (UpdateQuery) CTE ¶ added in v0.2.0
func (q UpdateQuery) CTE(name string, columns ...string) CTE
func (UpdateQuery) CustomJoin ¶
func (q UpdateQuery) CustomJoin(joinType JoinType, table Table, predicates ...Predicate) UpdateQuery
func (UpdateQuery) Exec ¶
func (q UpdateQuery) Exec(db DB, flag ExecFlag) (rowsAffected int64, err error)
func (UpdateQuery) ExecContext ¶
func (UpdateQuery) Fetch ¶
func (q UpdateQuery) Fetch(db DB) (err error)
func (UpdateQuery) FetchContext ¶
func (q UpdateQuery) FetchContext(ctx context.Context, db DB) (err error)
func (UpdateQuery) From ¶
func (q UpdateQuery) From(table Table) UpdateQuery
func (UpdateQuery) FullJoin ¶
func (q UpdateQuery) FullJoin(table Table, predicate Predicate, predicates ...Predicate) UpdateQuery
func (UpdateQuery) Join ¶
func (q UpdateQuery) Join(table Table, predicate Predicate, predicates ...Predicate) UpdateQuery
func (UpdateQuery) LeftJoin ¶
func (q UpdateQuery) LeftJoin(table Table, predicate Predicate, predicates ...Predicate) UpdateQuery
func (UpdateQuery) NestThis ¶
func (q UpdateQuery) NestThis() Query
func (UpdateQuery) Returning ¶
func (q UpdateQuery) Returning(fields ...Field) UpdateQuery
func (UpdateQuery) ReturningOne ¶
func (q UpdateQuery) ReturningOne() UpdateQuery
func (UpdateQuery) ReturningRowx ¶
func (q UpdateQuery) ReturningRowx(mapper func(*Row)) UpdateQuery
func (UpdateQuery) Returningx ¶
func (q UpdateQuery) Returningx(mapper func(*Row), accumulator func()) UpdateQuery
func (UpdateQuery) RightJoin ¶
func (q UpdateQuery) RightJoin(table Table, predicate Predicate, predicates ...Predicate) UpdateQuery
func (UpdateQuery) Set ¶
func (q UpdateQuery) Set(assignments ...Assignment) UpdateQuery
func (UpdateQuery) Setx ¶ added in v0.4.0
func (q UpdateQuery) Setx(mapper func(*Column)) UpdateQuery
func (UpdateQuery) Subquery ¶ added in v0.2.0
func (q UpdateQuery) Subquery(alias string) Subquery
func (UpdateQuery) ToSQL ¶
func (q UpdateQuery) ToSQL() (string, []interface{})
func (UpdateQuery) Update ¶
func (q UpdateQuery) Update(table BaseTable) UpdateQuery
func (UpdateQuery) Where ¶
func (q UpdateQuery) Where(predicates ...Predicate) UpdateQuery
func (UpdateQuery) With ¶
func (q UpdateQuery) With(ctes ...CTE) UpdateQuery
type VariadicPredicate ¶
type VariadicPredicate struct { Alias string Operator VariadicPredicateOperator Predicates []Predicate Negative bool // contains filtered or unexported fields }
VariadicPredicate represents the "x AND y AND z..." or "x OR y OR z..." SQL construct.
func And ¶
func And(predicates ...Predicate) VariadicPredicate
func Or ¶
func Or(predicates ...Predicate) VariadicPredicate
func (VariadicPredicate) AppendSQLExclude ¶
func (p VariadicPredicate) AppendSQLExclude(buf *strings.Builder, args *[]interface{}, excludedTableQualifiers []string)
ToSQL marshals the VariadicPredicate into an SQL query and args as described in the VariadicPredicate struct description.
func (VariadicPredicate) GetAlias ¶
func (p VariadicPredicate) GetAlias() string
GetAlias implements the Field interface.
func (VariadicPredicate) GetName ¶
func (p VariadicPredicate) GetName() string
GetName implements the Field interface.
func (VariadicPredicate) Not ¶
func (p VariadicPredicate) Not() Predicate
Not implements the Predicate interface.
type VariadicPredicateOperator ¶
type VariadicPredicateOperator string
VariadicPredicateOperator is an operator that can join a variadic number of Predicates together.
const ( PredicateOr VariadicPredicateOperator = "OR" PredicateAnd VariadicPredicateOperator = "AND" )
Possible VariadicOperators
type VariadicQuery ¶
type VariadicQuery struct { Operator VariadicQueryOperator Queries []Query // DB DB DB Mapper func(*Row) Accumulator func() // Logging Log Logger LogFlag LogFlag // contains filtered or unexported fields }
VariadicQuery represents a variadic number of queries joined together by an VariadicQueryOperator.
func Except ¶
func Except(queries ...Query) VariadicQuery
func ExceptAll ¶
func ExceptAll(queries ...Query) VariadicQuery
func Intersect ¶
func Intersect(queries ...Query) VariadicQuery
func IntersectAll ¶
func IntersectAll(queries ...Query) VariadicQuery
func Union ¶
func Union(queries ...Query) VariadicQuery
func UnionAll ¶
func UnionAll(queries ...Query) VariadicQuery
func (VariadicQuery) AppendSQL ¶
func (vq VariadicQuery) AppendSQL(buf *strings.Builder, args *[]interface{})
func (VariadicQuery) CTE ¶ added in v0.2.0
func (vq VariadicQuery) CTE(name string, columns ...string) CTE
func (VariadicQuery) NestThis ¶
func (vq VariadicQuery) NestThis() Query
func (VariadicQuery) Subquery ¶ added in v0.2.0
func (vq VariadicQuery) Subquery(name string) Subquery
func (VariadicQuery) ToSQL ¶
func (vq VariadicQuery) ToSQL() (string, []interface{})
type VariadicQueryOperator ¶
type VariadicQueryOperator string
VariadicQueryOperator is an operator that can join a variadic number of queries together.
const ( QueryUnion VariadicQueryOperator = "UNION" QueryUnionAll VariadicQueryOperator = "UNION ALL" QueryIntersect VariadicQueryOperator = "INTERSECT" QueryIntersectAll VariadicQueryOperator = "INTERSECT ALL" QueryExcept VariadicQueryOperator = "EXCEPT" QueryExceptAll VariadicQueryOperator = "EXCEPT ALL" )
VariadicQueryOperators
type Window ¶
type Window struct { WindowName string PartitionByFields Fields OrderByFields Fields FrameDefinition string // contains filtered or unexported fields }
func PartitionBy ¶
func (Window) PartitionBy ¶
Source Files ¶
- aggregate_functions.go
- array_field.go
- base_query.go
- binary_field.go
- boolean_field.go
- case.go
- column.go
- cte.go
- custom_field.go
- delete_query.go
- fields.go
- function_info.go
- insert_query.go
- join_table.go
- json_field.go
- number_field.go
- predicates.go
- row.go
- row_values.go
- select_query.go
- sq.go
- string_field.go
- string_util.go
- subquery.go
- table_info.go
- time_field.go
- update_query.go
- variadic_queries.go
- window.go