builder

package
v0.8.4 Latest Latest
Warning

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

Go to latest
Published: Mar 24, 2024 License: MIT Imports: 14 Imported by: 6

Documentation

Index

Examples

Constants

This section is empty.

Variables

View Source
var (
	ErrMissingRelationship = fmt.Errorf("missing relationship")
	ErrMissingField        = fmt.Errorf("missing related field")
)
View Source
var SoftDeletes = &Scope{
	Name: "soft-deletes",
	Apply: func(b *SubBuilder) *SubBuilder {
		return b.Where(b.GetTable()+".deleted_at", "=", nil)
	},
}

Functions

func Load

func Load(tx database.DB, v any, relation string) error

func LoadContext

func LoadContext(ctx context.Context, tx database.DB, v any, relation string) error

func LoadMissing

func LoadMissing(tx database.DB, v any, relation string) error

func LoadMissingContext

func LoadMissingContext(ctx context.Context, tx database.DB, v any, relation string) error

func NewSelects

func NewSelects() *selects

Types

type BelongsTo

type BelongsTo[T model.Model] struct {
	// contains filtered or unexported fields
}

BelongsTo represents a belongs to relationship on a model. The parent model with a BelongsTo property will have a column referencing another tables primary key. For example if model Foo had a BelongsTo[*Bar] property the foos table would have a foos.bar_id column related to the bars.id column. Struct tags can be used to change the column names if they don't follow the default naming convention. The column on the parent model can be set with a foreign tag and the column on the related model can be set with an owner tag.

Tags:

  • owner: parent model
  • foreign: related model
Example
sqlite.UseSQLite()
type Bar struct {
	model.BaseModel
	ID   int    `db:"id,autoincrement,primary"`
	Name string `db:"name"`
}

type Foo struct {
	model.BaseModel
	ID    int `db:"id,autoincrement,primary"`
	BarID int `db:"bar_id"`
	Bar   *builder.BelongsTo[*Bar]
}

db, _ := sqlx.Open("sqlite3", ":memory:")

createFoo, err := migrate.CreateFromModel(&Foo{})
check(err)
err = createFoo.Run(context.Background(), db)
check(err)
createBar, err := migrate.CreateFromModel(&Bar{})
check(err)
err = createBar.Run(context.Background(), db)
check(err)

foo := &Foo{BarID: 1}
err = model.Save(db, foo)
check(err)
bar := &Bar{ID: 1, Name: "bar name"}
err = model.Save(db, bar)
check(err)

err = builder.Load(db, foo, "Bar")
check(err)
relatedBar, _ := foo.Bar.Value()

fmt.Println(relatedBar.Name)
Output:

bar name

func (*BelongsTo[T]) ForeignKeys

func (r *BelongsTo[T]) ForeignKeys() []*ForeignKey

ForeignKeys returns a list of related tables and what columns they are related on.

func (*BelongsTo[T]) Initialize

func (r *BelongsTo[T]) Initialize(parent any, field reflect.StructField) error

func (*BelongsTo[T]) Load

func (r *BelongsTo[T]) Load(ctx context.Context, tx database.DB, relations []Relationship) error

func (*BelongsTo) Loaded

func (v *BelongsTo) Loaded() bool

Loaded returns true if the relationship has been fetched and false if it has not.

func (*BelongsTo) MarshalJSON

func (v *BelongsTo) MarshalJSON() ([]byte, error)

func (BelongsTo) Subquery

func (r BelongsTo) Subquery() *SubBuilder

Subquery returns a SubBuilder scoped to the relationship.

func (*BelongsTo) Value

func (v *BelongsTo) Value() (T, bool)

Value will return the related value and if it has been fetched.

type Builder

type Builder[T model.Model] struct {
	// contains filtered or unexported fields
}

Builder represents an sql query and any bindings needed to run it.

Example
package main

import (
	"fmt"

	"github.com/abibby/salusa/database/builder"
	"github.com/abibby/salusa/database/dialects"
	"github.com/abibby/salusa/internal/test"
)

func main() {
	query, bindings, err := builder.
		From[*test.Foo]().
		Where("column", "=", "value").
		ToSQL(dialects.New())
	if err != nil {
		panic(err)
	}

	fmt.Println(bindings)
	fmt.Println(query)
}
Output:

[value]
SELECT "foos".* FROM "foos" WHERE "column" = ?

func From

func From[T model.Model]() *Builder[T]

From creates a new query from the models table and with table.* selected

func New

func New[T model.Model]() *Builder[T]

New creates a new Builder with * selected

func NewEmpty

func NewEmpty[T model.Model]() *Builder[T]

NewEmpty creates a new helpers without anything selected

func (*Builder[T]) AddGroupBy

func (b *Builder[T]) AddGroupBy(columns ...string) *Builder[T]

GroupBy adds a "group by" clause to the query.

func (*Builder[T]) AddSelect

func (b *Builder[T]) AddSelect(columns ...string) *Builder[T]

AddSelect adds new columns to be selected.

func (*Builder[T]) AddSelectFunction

func (b *Builder[T]) AddSelectFunction(function, column string) *Builder[T]

SelectFunction adds a column to be selected with a function applied.

func (*Builder[T]) AddSelectSubquery

func (b *Builder[T]) AddSelectSubquery(sb QueryBuilder, as string) *Builder[T]

AddSelectSubquery adds a subquery to be selected.

func (*Builder[T]) And

func (b *Builder[T]) And(cb func(q *Conditions)) *Builder[T]

And adds a group of conditions to the query

func (*Builder[T]) Clone

func (b *Builder[T]) Clone() *Builder[T]

func (*Builder[T]) Context

func (b *Builder[T]) Context() context.Context

Context returns the context value from the query.

func (*Builder[T]) CrossJoin

func (b *Builder[T]) CrossJoin(table, localColumn, operator, foreignColumn string) *Builder[T]

CrossJoin adds a cross join clause to the query.

func (*Builder[T]) CrossJoinOn

func (b *Builder[T]) CrossJoinOn(table string, cb func(q *Conditions)) *Builder[T]

CrossJoinOn adds a cross join clause to the query with a complex on statement.

func (*Builder[T]) Delete added in v0.7.0

func (b *Builder[T]) Delete(tx database.DB) error

func (*Builder[T]) Deleter added in v0.7.0

func (b *Builder[T]) Deleter() *Deleter

func (*Builder[T]) Distinct

func (b *Builder[T]) Distinct() *Builder[T]

Distinct forces the query to only return distinct results.

func (*Builder[T]) Dump

func (b *Builder[T]) Dump() *Builder[T]

func (*Builder[T]) Each

func (b *Builder[T]) Each(tx database.DB, cb func(v T) error) error

func (*Builder[T]) Find

func (b *Builder[T]) Find(tx database.DB, primaryKeyValue any) (T, error)

Find returns the record with a matching primary key. It will fail on tables with multiple primary keys.

func (*Builder[T]) First

func (b *Builder[T]) First(tx database.DB) (T, error)

Get executes the query as a select statement and returns the first record.

func (*Builder[T]) From

func (b *Builder[T]) From(table string) *Builder[T]

From sets the table which the query is targeting.

func (*Builder[T]) Get

func (b *Builder[T]) Get(tx database.DB) ([]T, error)

Get executes the query as a select statement and returns the result.

func (*Builder[T]) GetTable

func (b *Builder[T]) GetTable() string

GetTable returns the table the query is targeting

func (*Builder[T]) GroupBy

func (b *Builder[T]) GroupBy(columns ...string) *Builder[T]

GroupBy sets the "group by" clause to the query.

func (*Builder[T]) Having

func (b *Builder[T]) Having(column, operator string, value any) *Builder[T]

Having adds a basic having clause to the query.

func (*Builder[T]) HavingAnd

func (b *Builder[T]) HavingAnd(cb func(q *Conditions)) *Builder[T]

HavingAnd adds a group of conditions to the query

func (*Builder[T]) HavingColumn

func (b *Builder[T]) HavingColumn(column, operator string, valueColumn string) *Builder[T]

HavingColumn adds a having clause to the query comparing two columns.

func (*Builder[T]) HavingExists

func (b *Builder[T]) HavingExists(query QueryBuilder) *Builder[T]

HavingExists add an exists clause to the query.

func (*Builder[T]) HavingHas

func (b *Builder[T]) HavingHas(relation string, cb func(q *SubBuilder) *SubBuilder) *Builder[T]

HavingHas adds a relationship exists condition to the query with having clauses.

func (*Builder[T]) HavingIn

func (b *Builder[T]) HavingIn(column string, values []any) *Builder[T]

HavingIn adds a having in clause to the query.

func (*Builder[T]) HavingOr

func (b *Builder[T]) HavingOr(cb func(q *Conditions)) *Builder[T]

HavingOr adds a group of conditions to the query with an or

func (*Builder[T]) HavingRaw

func (b *Builder[T]) HavingRaw(rawSql string, bindings ...any) *Builder[T]

HavingRaw adds a raw having clause to the query.

func (*Builder[T]) HavingSubquery

func (b *Builder[T]) HavingSubquery(subquery QueryBuilder, operator string, value any) *Builder[T]

HavingSubquery adds a having clause to the query comparing a column and a subquery.

func (*Builder[T]) InnerJoin

func (b *Builder[T]) InnerJoin(table, localColumn, operator, foreignColumn string) *Builder[T]

InnerJoin adds an inner join clause to the query.

func (*Builder[T]) InnerJoinOn

func (b *Builder[T]) InnerJoinOn(table string, cb func(q *Conditions)) *Builder[T]

InnerJoinOn adds an inner join clause to the query with a complex on statement.

func (*Builder[T]) Join

func (b *Builder[T]) Join(table, localColumn, operator, foreignColumn string) *Builder[T]

Join adds a join clause to the query.

func (*Builder[T]) JoinOn

func (b *Builder[T]) JoinOn(table string, cb func(q *Conditions)) *Builder[T]

JoinOn adds a join clause to the query with a complex on statement.

func (*Builder[T]) LeftJoin

func (b *Builder[T]) LeftJoin(table, localColumn, operator, foreignColumn string) *Builder[T]

LeftJoin adds a left join clause to the query.

func (*Builder[T]) LeftJoinOn

func (b *Builder[T]) LeftJoinOn(table string, cb func(q *Conditions)) *Builder[T]

LeftJoinOn adds a left join clause to the query with a complex on statement.

func (*Builder[T]) Limit

func (b *Builder[T]) Limit(limit int) *Builder[T]

Limit set the maximum number of rows to return.

func (*Builder[T]) Load

func (b *Builder[T]) Load(tx database.DB, v any) error

Load executes the query as a select statement and sets v to the result.

func (*Builder[T]) LoadOne

func (b *Builder[T]) LoadOne(tx database.DB, v any) error

Load executes the query as a select statement and sets v to the result.

func (*Builder[T]) Offset

func (b *Builder[T]) Offset(offset int) *Builder[T]

Offset sets the number of rows to skip before returning the result.

func (*Builder[T]) Or

func (b *Builder[T]) Or(cb func(q *Conditions)) *Builder[T]

Or adds a group of conditions to the query with an or

func (*Builder[T]) OrHaving

func (b *Builder[T]) OrHaving(column, operator string, value any) *Builder[T]

OrHaving adds an or having clause to the query

func (*Builder[T]) OrHavingColumn

func (b *Builder[T]) OrHavingColumn(column, operator string, valueColumn string) *Builder[T]

OrHavingColumn adds an or having clause to the query comparing two columns.

func (*Builder[T]) OrHavingExists

func (b *Builder[T]) OrHavingExists(query QueryBuilder) *Builder[T]

WhereExists add an exists clause to the query.

func (*Builder[T]) OrHavingHas

func (b *Builder[T]) OrHavingHas(relation string, cb func(q *SubBuilder) *SubBuilder) *Builder[T]

OrHavingHas adds a relationship exists condition to the query with having clauses and an or.

func (*Builder[T]) OrHavingIn

func (b *Builder[T]) OrHavingIn(column string, values []any) *Builder[T]

OrHavingIn adds an or having in clause to the query.

func (*Builder[T]) OrHavingRaw

func (b *Builder[T]) OrHavingRaw(rawSql string, bindings ...any) *Builder[T]

OrHavingRaw adds a raw or having clause to the query.

func (*Builder[T]) OrHavingSubquery

func (b *Builder[T]) OrHavingSubquery(subquery QueryBuilder, operator string, value any) *Builder[T]

OrHavingSubquery adds an or having clause to the query comparing a column and a subquery.

func (*Builder[T]) OrWhere

func (b *Builder[T]) OrWhere(column, operator string, value any) *Builder[T]

OrWhere adds an or where clause to the query

func (*Builder[T]) OrWhereColumn

func (b *Builder[T]) OrWhereColumn(column, operator string, valueColumn string) *Builder[T]

OrWhereColumn adds an or where clause to the query comparing two columns.

func (*Builder[T]) OrWhereExists

func (b *Builder[T]) OrWhereExists(query QueryBuilder) *Builder[T]

WhereExists add an exists clause to the query.

func (*Builder[T]) OrWhereHas

func (b *Builder[T]) OrWhereHas(relation string, cb func(q *SubBuilder) *SubBuilder) *Builder[T]

OrWhereHas adds a relationship exists condition to the query with where clauses and an or.

func (*Builder[T]) OrWhereIn

func (b *Builder[T]) OrWhereIn(column string, values []any) *Builder[T]

OrWhereIn adds an or where in clause to the query.

func (*Builder[T]) OrWhereRaw

func (b *Builder[T]) OrWhereRaw(rawSql string, bindings ...any) *Builder[T]

OrWhereRaw adds a raw or where clause to the query.

func (*Builder[T]) OrWhereSubquery

func (b *Builder[T]) OrWhereSubquery(subquery QueryBuilder, operator string, value any) *Builder[T]

OrWhereSubquery adds an or where clause to the query comparing a column and a subquery.

func (*Builder[T]) OrderBy

func (b *Builder[T]) OrderBy(column string) *Builder[T]

OrderBy adds an order by clause to the query.

func (*Builder[T]) OrderByDesc

func (b *Builder[T]) OrderByDesc(column string) *Builder[T]

OrderByDesc adds a descending order by clause to the query.

func (*Builder[T]) RightJoin

func (b *Builder[T]) RightJoin(table, localColumn, operator, foreignColumn string) *Builder[T]

RightJoin adds a right join clause to the query.

func (*Builder[T]) RightJoinOn

func (b *Builder[T]) RightJoinOn(table string, cb func(q *Conditions)) *Builder[T]

RightJoinOn adds a right join clause to the query with a complex on statement.

func (*Builder[T]) Select

func (b *Builder[T]) Select(columns ...string) *Builder[T]

Select sets the columns to be selected.

func (*Builder[T]) SelectFunction

func (b *Builder[T]) SelectFunction(function, column string) *Builder[T]

SelectFunction sets a column to be selected with a function applied.

func (*Builder[T]) SelectSubquery

func (b *Builder[T]) SelectSubquery(sb QueryBuilder, as string) *Builder[T]

SelectSubquery sets a subquery to be selected.

func (*Builder[T]) ToSQL

func (b *Builder[T]) ToSQL(d dialects.Dialect) (string, []any, error)

func (*Builder[T]) Unordered

func (b *Builder[T]) Unordered() *Builder[T]

Unordered removes all order by clauses from the query.

func (*Builder[T]) Where

func (b *Builder[T]) Where(column, operator string, value any) *Builder[T]

Where adds a basic where clause to the query.

func (*Builder[T]) WhereColumn

func (b *Builder[T]) WhereColumn(column, operator string, valueColumn string) *Builder[T]

WhereColumn adds a where clause to the query comparing two columns.

func (*Builder[T]) WhereExists

func (b *Builder[T]) WhereExists(query QueryBuilder) *Builder[T]

WhereExists add an exists clause to the query.

func (*Builder[T]) WhereHas

func (b *Builder[T]) WhereHas(relation string, cb func(q *SubBuilder) *SubBuilder) *Builder[T]

WhereHas adds a relationship exists condition to the query with where clauses.

Example
package main

import (
	"fmt"

	"github.com/abibby/salusa/database/builder"
	"github.com/abibby/salusa/database/dialects"
	"github.com/abibby/salusa/internal/test"
)

func main() {
	query, bindings, err := builder.
		From[*test.Foo]().
		WhereHas("Bar", func(q *builder.SubBuilder) *builder.SubBuilder {
			return q.Where("id", "=", 7)
		}).
		ToSQL(dialects.New())
	if err != nil {
		panic(err)
	}

	fmt.Println(bindings)
	fmt.Println(query)
}
Output:

[7]
SELECT "foos".* FROM "foos" WHERE EXISTS (SELECT "bars".* FROM "bars" WHERE "foo_id" = "foos"."id" AND "id" = ?)

func (*Builder[T]) WhereIn

func (b *Builder[T]) WhereIn(column string, values []any) *Builder[T]

WhereIn adds a where in clause to the query.

func (*Builder[T]) WhereRaw

func (b *Builder[T]) WhereRaw(rawSql string, bindings ...any) *Builder[T]

WhereRaw adds a raw where clause to the query.

func (*Builder[T]) WhereSubquery

func (b *Builder[T]) WhereSubquery(subquery QueryBuilder, operator string, value any) *Builder[T]

WhereSubquery adds a where clause to the query comparing a column and a subquery.

func (*Builder[T]) With

func (b *Builder[T]) With(withs ...string) *Builder[T]

func (*Builder[T]) WithContext

func (b *Builder[T]) WithContext(ctx context.Context) *Builder[T]

WithContext adds a context to the query that will be used when fetching results.

func (*Builder[T]) WithScope

func (b *Builder[T]) WithScope(scope *Scope) *Builder[T]

WithScope adds a local scope to a query.

func (*Builder[T]) WithoutGlobalScope

func (b *Builder[T]) WithoutGlobalScope(scope *Scope) *Builder[T]

WithoutGlobalScope removes a global scope from the query.

func (*Builder[T]) WithoutScope

func (b *Builder[T]) WithoutScope(scope *Scope) *Builder[T]

WithoutScope removes the given scope from the local scopes.

type Conditions

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

func (*Conditions) And

func (c *Conditions) And(cb func(q *Conditions)) *Conditions

And adds a group of conditions to the query

func (*Conditions) Clone

func (c *Conditions) Clone() *Conditions

func (*Conditions) Or

func (c *Conditions) Or(cb func(q *Conditions)) *Conditions

Or adds a group of conditions to the query with an or

func (*Conditions) OrWhere

func (c *Conditions) OrWhere(column, operator string, value any) *Conditions

OrWhere adds an or where clause to the query

func (*Conditions) OrWhereColumn

func (c *Conditions) OrWhereColumn(column, operator string, valueColumn string) *Conditions

OrWhereColumn adds an or where clause to the query comparing two columns.

func (*Conditions) OrWhereExists

func (c *Conditions) OrWhereExists(query QueryBuilder) *Conditions

WhereExists add an exists clause to the query.

func (*Conditions) OrWhereHas

func (c *Conditions) OrWhereHas(relation string, cb func(q *SubBuilder) *SubBuilder) *Conditions

OrWhereHas adds a relationship exists condition to the query with where clauses and an or.

func (*Conditions) OrWhereIn

func (c *Conditions) OrWhereIn(column string, values []any) *Conditions

OrWhereIn adds an or where in clause to the query.

func (*Conditions) OrWhereRaw

func (c *Conditions) OrWhereRaw(rawSql string, bindings ...any) *Conditions

OrWhereRaw adds a raw or where clause to the query.

func (*Conditions) OrWhereSubquery

func (c *Conditions) OrWhereSubquery(subquery QueryBuilder, operator string, value any) *Conditions

OrWhereSubquery adds an or where clause to the query comparing a column and a subquery.

func (*Conditions) ToSQL

func (c *Conditions) ToSQL(d dialects.Dialect) (string, []any, error)

func (*Conditions) Where

func (c *Conditions) Where(column, operator string, value any) *Conditions

Where adds a basic where clause to the query.

func (*Conditions) WhereColumn

func (c *Conditions) WhereColumn(column, operator string, valueColumn string) *Conditions

WhereColumn adds a where clause to the query comparing two columns.

func (*Conditions) WhereExists

func (c *Conditions) WhereExists(query QueryBuilder) *Conditions

WhereExists add an exists clause to the query.

func (*Conditions) WhereHas

func (c *Conditions) WhereHas(relation string, cb func(q *SubBuilder) *SubBuilder) *Conditions

WhereHas adds a relationship exists condition to the query with where clauses.

func (*Conditions) WhereIn

func (c *Conditions) WhereIn(column string, values []any) *Conditions

WhereIn adds a where in clause to the query.

func (*Conditions) WhereRaw

func (c *Conditions) WhereRaw(rawSql string, bindings ...any) *Conditions

WhereRaw adds a raw where clause to the query.

func (*Conditions) WhereSubquery

func (c *Conditions) WhereSubquery(subquery QueryBuilder, operator string, value any) *Conditions

WhereSubquery adds a where clause to the query comparing a column and a subquery.

type Deleter added in v0.7.0

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

func (*Deleter) ToSQL added in v0.7.0

func (d *Deleter) ToSQL(dialect dialects.Dialect) (string, []any, error)

type ForeignKey

type ForeignKey struct {
	LocalKey     string
	RelatedTable string
	RelatedKey   string
}

func (*ForeignKey) Equal

func (f *ForeignKey) Equal(v *ForeignKey) bool

type HasMany

type HasMany[T model.Model] struct {
	// contains filtered or unexported fields
}

Tags:

  • local: parent model
  • foreign: related model

func (*HasMany[T]) ForeignKeys

func (r *HasMany[T]) ForeignKeys() []*ForeignKey

ForeignKeys returns a list of related tables and what columns they are related on.

func (*HasMany[T]) Initialize

func (r *HasMany[T]) Initialize(parent any, field reflect.StructField) error

func (*HasMany[T]) Load

func (r *HasMany[T]) Load(ctx context.Context, tx database.DB, relations []Relationship) error

func (*HasMany) Loaded

func (v *HasMany) Loaded() bool

Loaded returns true if the relationship has been fetched and false if it has not.

func (*HasMany) MarshalJSON

func (v *HasMany) MarshalJSON() ([]byte, error)

func (HasMany) Subquery

func (r HasMany) Subquery() *SubBuilder

Subquery returns a SubBuilder scoped to the relationship.

func (*HasMany) Value

func (v *HasMany) Value() (T, bool)

Value will return the related value and if it has been fetched.

type HasOne

type HasOne[T model.Model] struct {
	// contains filtered or unexported fields
}

Tags:

  • local: parent model
  • foreign: related model

func (*HasOne[T]) ForeignKeys

func (r *HasOne[T]) ForeignKeys() []*ForeignKey

ForeignKeys returns a list of related tables and what columns they are related on.

func (*HasOne[T]) Initialize

func (r *HasOne[T]) Initialize(parent any, field reflect.StructField) error

func (*HasOne[T]) Load

func (r *HasOne[T]) Load(ctx context.Context, tx database.DB, relations []Relationship) error

func (*HasOne) Loaded

func (v *HasOne) Loaded() bool

Loaded returns true if the relationship has been fetched and false if it has not.

func (*HasOne) MarshalJSON

func (v *HasOne) MarshalJSON() ([]byte, error)

func (HasOne) Subquery

func (r HasOne) Subquery() *SubBuilder

Subquery returns a SubBuilder scoped to the relationship.

func (*HasOne) Value

func (v *HasOne) Value() (T, bool)

Value will return the related value and if it has been fetched.

type QueryBuilder

type QueryBuilder interface {
	helpers.ToSQLer
	// contains filtered or unexported methods
}

QueryBuilder is implemented by *Builder and *SubBuilder

type Relationship

type Relationship interface {
	relationship.Relationship
	Subquery() *SubBuilder
	Load(ctx context.Context, tx database.DB, relations []Relationship) error
	ForeignKeys() []*ForeignKey
}

type Scope

type Scope struct {
	Name  string
	Apply ScopeFunc
}

Scope is a modifier for a query that can be easily applied.

type ScopeFunc

type ScopeFunc func(b *SubBuilder) *SubBuilder

type Scoper

type Scoper interface {
	Scopes() []*Scope
}

type SubBuilder

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

func NewSubBuilder

func NewSubBuilder() *SubBuilder

NewSubBuilder creates a new SubBuilder without anything selected

func (*SubBuilder) AddGroupBy

func (b *SubBuilder) AddGroupBy(columns ...string) *SubBuilder

GroupBy adds a "group by" clause to the query.

func (*SubBuilder) AddSelect

func (b *SubBuilder) AddSelect(columns ...string) *SubBuilder

AddSelect adds new columns to be selected.

func (*SubBuilder) AddSelectFunction

func (b *SubBuilder) AddSelectFunction(function, column string) *SubBuilder

SelectFunction adds a column to be selected with a function applied.

func (*SubBuilder) AddSelectSubquery

func (b *SubBuilder) AddSelectSubquery(sb QueryBuilder, as string) *SubBuilder

AddSelectSubquery adds a subquery to be selected.

func (*SubBuilder) And

func (b *SubBuilder) And(cb func(q *Conditions)) *SubBuilder

And adds a group of conditions to the query

func (*SubBuilder) Clone

func (b *SubBuilder) Clone() *SubBuilder

func (*SubBuilder) Context

func (b *SubBuilder) Context() context.Context

Context returns the context value from the query.

func (*SubBuilder) CrossJoin

func (b *SubBuilder) CrossJoin(table, localColumn, operator, foreignColumn string) *SubBuilder

CrossJoin adds a cross join clause to the query.

func (*SubBuilder) CrossJoinOn

func (b *SubBuilder) CrossJoinOn(table string, cb func(q *Conditions)) *SubBuilder

CrossJoinOn adds a cross join clause to the query with a complex on statement.

func (*SubBuilder) Delete added in v0.7.0

func (b *SubBuilder) Delete(tx database.DB) error

func (*SubBuilder) Deleter added in v0.7.0

func (b *SubBuilder) Deleter() *Deleter

func (*SubBuilder) Distinct

func (b *SubBuilder) Distinct() *SubBuilder

Distinct forces the query to only return distinct results.

func (*SubBuilder) Dump

func (b *SubBuilder) Dump() *SubBuilder

func (*SubBuilder) From

func (b *SubBuilder) From(table string) *SubBuilder

From sets the table which the query is targeting.

func (*SubBuilder) GetTable

func (b *SubBuilder) GetTable() string

GetTable returns the table the query is targeting

func (*SubBuilder) GroupBy

func (b *SubBuilder) GroupBy(columns ...string) *SubBuilder

GroupBy sets the "group by" clause to the query.

func (*SubBuilder) Having

func (b *SubBuilder) Having(column, operator string, value any) *SubBuilder

Having adds a basic having clause to the query.

func (*SubBuilder) HavingAnd

func (b *SubBuilder) HavingAnd(cb func(q *Conditions)) *SubBuilder

HavingAnd adds a group of conditions to the query

func (*SubBuilder) HavingColumn

func (b *SubBuilder) HavingColumn(column, operator string, valueColumn string) *SubBuilder

HavingColumn adds a having clause to the query comparing two columns.

func (*SubBuilder) HavingExists

func (b *SubBuilder) HavingExists(query QueryBuilder) *SubBuilder

HavingExists add an exists clause to the query.

func (*SubBuilder) HavingHas

func (b *SubBuilder) HavingHas(relation string, cb func(q *SubBuilder) *SubBuilder) *SubBuilder

HavingHas adds a relationship exists condition to the query with having clauses.

func (*SubBuilder) HavingIn

func (b *SubBuilder) HavingIn(column string, values []any) *SubBuilder

HavingIn adds a having in clause to the query.

func (*SubBuilder) HavingOr

func (b *SubBuilder) HavingOr(cb func(q *Conditions)) *SubBuilder

HavingOr adds a group of conditions to the query with an or

func (*SubBuilder) HavingRaw

func (b *SubBuilder) HavingRaw(rawSql string, bindings ...any) *SubBuilder

HavingRaw adds a raw having clause to the query.

func (*SubBuilder) HavingSubquery

func (b *SubBuilder) HavingSubquery(subquery QueryBuilder, operator string, value any) *SubBuilder

HavingSubquery adds a having clause to the query comparing a column and a subquery.

func (*SubBuilder) InnerJoin

func (b *SubBuilder) InnerJoin(table, localColumn, operator, foreignColumn string) *SubBuilder

InnerJoin adds an inner join clause to the query.

func (*SubBuilder) InnerJoinOn

func (b *SubBuilder) InnerJoinOn(table string, cb func(q *Conditions)) *SubBuilder

InnerJoinOn adds an inner join clause to the query with a complex on statement.

func (*SubBuilder) Join

func (b *SubBuilder) Join(table, localColumn, operator, foreignColumn string) *SubBuilder

Join adds a join clause to the query.

func (*SubBuilder) JoinOn

func (b *SubBuilder) JoinOn(table string, cb func(q *Conditions)) *SubBuilder

JoinOn adds a join clause to the query with a complex on statement.

func (*SubBuilder) LeftJoin

func (b *SubBuilder) LeftJoin(table, localColumn, operator, foreignColumn string) *SubBuilder

LeftJoin adds a left join clause to the query.

func (*SubBuilder) LeftJoinOn

func (b *SubBuilder) LeftJoinOn(table string, cb func(q *Conditions)) *SubBuilder

LeftJoinOn adds a left join clause to the query with a complex on statement.

func (*SubBuilder) Limit

func (b *SubBuilder) Limit(limit int) *SubBuilder

Limit set the maximum number of rows to return.

func (*SubBuilder) Load added in v0.8.0

func (b *SubBuilder) Load(tx database.DB, v any) error

Load executes the query as a select statement and sets v to the result.

func (*SubBuilder) LoadOne added in v0.8.0

func (b *SubBuilder) LoadOne(tx database.DB, v any) error

Load executes the query as a select statement and sets v to the first record.

func (*SubBuilder) Offset

func (b *SubBuilder) Offset(offset int) *SubBuilder

Offset sets the number of rows to skip before returning the result.

func (*SubBuilder) Or

func (b *SubBuilder) Or(cb func(q *Conditions)) *SubBuilder

Or adds a group of conditions to the query with an or

func (*SubBuilder) OrHaving

func (b *SubBuilder) OrHaving(column, operator string, value any) *SubBuilder

OrHaving adds an or having clause to the query

func (*SubBuilder) OrHavingColumn

func (b *SubBuilder) OrHavingColumn(column, operator string, valueColumn string) *SubBuilder

OrHavingColumn adds an or having clause to the query comparing two columns.

func (*SubBuilder) OrHavingExists

func (b *SubBuilder) OrHavingExists(query QueryBuilder) *SubBuilder

WhereExists add an exists clause to the query.

func (*SubBuilder) OrHavingHas

func (b *SubBuilder) OrHavingHas(relation string, cb func(q *SubBuilder) *SubBuilder) *SubBuilder

OrHavingHas adds a relationship exists condition to the query with having clauses and an or.

func (*SubBuilder) OrHavingIn

func (b *SubBuilder) OrHavingIn(column string, values []any) *SubBuilder

OrHavingIn adds an or having in clause to the query.

func (*SubBuilder) OrHavingRaw

func (b *SubBuilder) OrHavingRaw(rawSql string, bindings ...any) *SubBuilder

OrHavingRaw adds a raw or having clause to the query.

func (*SubBuilder) OrHavingSubquery

func (b *SubBuilder) OrHavingSubquery(subquery QueryBuilder, operator string, value any) *SubBuilder

OrHavingSubquery adds an or having clause to the query comparing a column and a subquery.

func (*SubBuilder) OrWhere

func (b *SubBuilder) OrWhere(column, operator string, value any) *SubBuilder

OrWhere adds an or where clause to the query

func (*SubBuilder) OrWhereColumn

func (b *SubBuilder) OrWhereColumn(column, operator string, valueColumn string) *SubBuilder

OrWhereColumn adds an or where clause to the query comparing two columns.

func (*SubBuilder) OrWhereExists

func (b *SubBuilder) OrWhereExists(query QueryBuilder) *SubBuilder

WhereExists add an exists clause to the query.

func (*SubBuilder) OrWhereHas

func (b *SubBuilder) OrWhereHas(relation string, cb func(q *SubBuilder) *SubBuilder) *SubBuilder

OrWhereHas adds a relationship exists condition to the query with where clauses and an or.

func (*SubBuilder) OrWhereIn

func (b *SubBuilder) OrWhereIn(column string, values []any) *SubBuilder

OrWhereIn adds an or where in clause to the query.

func (*SubBuilder) OrWhereRaw

func (b *SubBuilder) OrWhereRaw(rawSql string, bindings ...any) *SubBuilder

OrWhereRaw adds a raw or where clause to the query.

func (*SubBuilder) OrWhereSubquery

func (b *SubBuilder) OrWhereSubquery(subquery QueryBuilder, operator string, value any) *SubBuilder

OrWhereSubquery adds an or where clause to the query comparing a column and a subquery.

func (*SubBuilder) OrderBy

func (b *SubBuilder) OrderBy(column string) *SubBuilder

OrderBy adds an order by clause to the query.

func (*SubBuilder) OrderByDesc

func (b *SubBuilder) OrderByDesc(column string) *SubBuilder

OrderByDesc adds a descending order by clause to the query.

func (*SubBuilder) RightJoin

func (b *SubBuilder) RightJoin(table, localColumn, operator, foreignColumn string) *SubBuilder

RightJoin adds a right join clause to the query.

func (*SubBuilder) RightJoinOn

func (b *SubBuilder) RightJoinOn(table string, cb func(q *Conditions)) *SubBuilder

RightJoinOn adds a right join clause to the query with a complex on statement.

func (*SubBuilder) Select

func (b *SubBuilder) Select(columns ...string) *SubBuilder

Select sets the columns to be selected.

func (*SubBuilder) SelectFunction

func (b *SubBuilder) SelectFunction(function, column string) *SubBuilder

SelectFunction sets a column to be selected with a function applied.

func (*SubBuilder) SelectSubquery

func (b *SubBuilder) SelectSubquery(sb QueryBuilder, as string) *SubBuilder

SelectSubquery sets a subquery to be selected.

func (*SubBuilder) ToSQL

func (b *SubBuilder) ToSQL(d dialects.Dialect) (string, []any, error)

func (*SubBuilder) Unordered

func (b *SubBuilder) Unordered() *SubBuilder

Unordered removes all order by clauses from the query.

func (*SubBuilder) Where

func (b *SubBuilder) Where(column, operator string, value any) *SubBuilder

Where adds a basic where clause to the query.

func (*SubBuilder) WhereColumn

func (b *SubBuilder) WhereColumn(column, operator string, valueColumn string) *SubBuilder

WhereColumn adds a where clause to the query comparing two columns.

func (*SubBuilder) WhereExists

func (b *SubBuilder) WhereExists(query QueryBuilder) *SubBuilder

WhereExists add an exists clause to the query.

func (*SubBuilder) WhereHas

func (b *SubBuilder) WhereHas(relation string, cb func(q *SubBuilder) *SubBuilder) *SubBuilder

WhereHas adds a relationship exists condition to the query with where clauses.

func (*SubBuilder) WhereIn

func (b *SubBuilder) WhereIn(column string, values []any) *SubBuilder

WhereIn adds a where in clause to the query.

func (*SubBuilder) WhereRaw

func (b *SubBuilder) WhereRaw(rawSql string, bindings ...any) *SubBuilder

WhereRaw adds a raw where clause to the query.

func (*SubBuilder) WhereSubquery

func (b *SubBuilder) WhereSubquery(subquery QueryBuilder, operator string, value any) *SubBuilder

WhereSubquery adds a where clause to the query comparing a column and a subquery.

func (*SubBuilder) WithContext

func (b *SubBuilder) WithContext(ctx context.Context) *SubBuilder

WithContext adds a context to the query that will be used when fetching results.

func (*SubBuilder) WithScope

func (b *SubBuilder) WithScope(scope *Scope) *SubBuilder

WithScope adds a local scope to a query.

func (*SubBuilder) WithoutGlobalScope

func (b *SubBuilder) WithoutGlobalScope(scope *Scope) *SubBuilder

WithoutGlobalScope removes a global scope from the query.

func (*SubBuilder) WithoutScope

func (b *SubBuilder) WithoutScope(scope *Scope) *SubBuilder

WithoutScope removes the given scope from the local scopes.

Jump to

Keyboard shortcuts

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