Documentation ¶
Index ¶
- func CombineWithOr(qms []qm.QueryMod) []qm.QueryMod
- func ILike(val string, path ...string) qm.QueryMod
- func InnerJoin(baseTable string, baseColumn string, joinTable string, joinColumn string) qm.QueryMod
- func InnerJoinWithFilter(baseTable string, baseColumn string, joinTable string, joinColumn string, ...) qm.QueryMod
- func LeftOuterJoin(baseTable string, baseColumn string, joinTable string, joinColumn string) qm.QueryMod
- func LeftOuterJoinWithFilter(baseTable string, baseColumn string, joinTable string, joinColumn string, ...) qm.QueryMod
- func NullFloat32FromFloat64Ptr(f *float64) null.Float32
- func NullIntFromInt64Ptr(i *int64) null.Int
- func OrderBy(orderDir types.OrderDir, path ...string) qm.QueryMod
- func OrderByLower(orderDir types.OrderDir, path ...string) qm.QueryMod
- func OrderByLowerWithNulls(orderDir types.OrderDir, orderByNulls OrderByNulls, path ...string) qm.QueryMod
- func OrderByWithNulls(orderDir types.OrderDir, orderByNulls OrderByNulls, path ...string) qm.QueryMod
- func SearchStringToTSQuery(s *string) string
- func WhereJSON(table string, column string, filter interface{}) qm.QueryMod
- func WithConfiguredTransaction(ctx context.Context, db *sql.DB, options *sql.TxOptions, fn TxFn) error
- func WithTransaction(ctx context.Context, db *sql.DB, fn TxFn) error
- type OrderByNulls
- type QueryMods
- type TxFn
Examples ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func CombineWithOr ¶
CombineWithOr receives a slice of query mods and returns a new slice with a single query mod, combining all other query mods into an OR expression.
func ILike ¶
ILike returns a query mod containing a pre-formatted ILIKE clause. The value provided is applied directly - to perform a wildcard search, enclose the desired search value in `%` as desired before passing it to ILike. The path provided will be joined to construct the full SQL path used, allowing for filtering of values nested across multiple joins if needed.
func InnerJoin ¶
func InnerJoin(baseTable string, baseColumn string, joinTable string, joinColumn string) qm.QueryMod
InnerJoin returns an InnerJoin QueryMod formatted using the provided join tables and columns.
func InnerJoinWithFilter ¶
func InnerJoinWithFilter(baseTable string, baseColumn string, joinTable string, joinColumn string, filterColumn string, filterValue interface{}, optFilterTable ...string) qm.QueryMod
InnerJoinWithFilter returns an InnerJoin QueryMod formatted using the provided join tables and columns including an additional filter condition. Omitting the optional filter table will use the provided join table as a base for the filter.
func LeftOuterJoin ¶
func LeftOuterJoin(baseTable string, baseColumn string, joinTable string, joinColumn string) qm.QueryMod
LeftOuterJoin returns an LeftOuterJoin QueryMod formatted using the provided join tables and columns.
func LeftOuterJoinWithFilter ¶
func LeftOuterJoinWithFilter(baseTable string, baseColumn string, joinTable string, joinColumn string, filterColumn string, filterValue interface{}, optFilterTable ...string) qm.QueryMod
LeftOuterJoinWithFilter returns an LeftOuterJoin QueryMod formatted using the provided join tables and columns including an additional filter condition. Omitting the optional filter table will use the provided join table as a base for the filter.
func NullFloat32FromFloat64Ptr ¶
func NullFloat32FromFloat64Ptr(f *float64) null.Float32
func NullIntFromInt64Ptr ¶
func NullIntFromInt64Ptr(i *int64) null.Int
func OrderByLowerWithNulls ¶
func OrderByWithNulls ¶
func SearchStringToTSQuery ¶
SearchStringToTSQuery returns a TSQuery string from user input. The resulting query will match if every word matches a beginning of a word in the row. This function will trim all leading and trailing as well as consecutive whitespaces and remove all single quotes before transforming the input into TSQuery syntax. If no input was given (nil or empty string) or the value only contains invalid characters, an empty string will be returned.
func WhereJSON ¶
WhereJSON constructs a QueryMod for querying a JSONB column.
The filter interface provided is inspected using reflection, all fields with a (non-empty) `json` tag will be added to the query and combined using `AND` - fields tagged with `json:"-"` will be ignored as well. Alternatively, a string can be provided, performing a string comparison with the database value (the stored JSON value does not necessarily have to be a string, but could be an integer or similar). The `json` tag's (first) value will be used as the "key" for the query, allowing for field renaming or different capitalizations.
At the moment, the root level `filter` value must either be a struct or a string. WhereJSON will panic should it encounter a type it cannot process or the filter provided results in an empty QueryMod - this allows for easier call chaining at the expense of panics in case of incorrect filters being passed.
WhereJSON should support all basic types as well as pointers and array/slices of those out of the box, given the Postgres driver can handle their serialization. nil pointers are skipped automatically. At the moment, struct fields are only supported for composition purposes: if a struct is encountered, WhereJSON recursively traverses it (up to 10 levels deep) and adds all eligible fields to the top level query. Should an array or slice be encountered, their values will be added using the `<@` JSONB operator, checking whether all entries existx at the top level within the JSON column. At the time of writing, no support for special database/HTTP types such as the `null` or `strfmt` packages exists - use their respective base types instead.
Whilst WhereJSON was designed to be used with Postgres' JSONB column type, the current implementation also supports the JSON type as long as the filter struct does not contain any arrays or slices. Note that this compatibility might change at some point in the future, so it is advised to use the JSONB data type unless your requirements do not allow for it.
Example ¶
package main import ( "fmt" "github.com/danielmoisa/trip-planner/internal/models" "github.com/danielmoisa/trip-planner/internal/util/db" "github.com/volatiletech/sqlboiler/v4/queries" "github.com/volatiletech/sqlboiler/v4/queries/qm" ) type PublicName struct { First string `json:"firstName"` } type Name struct { PublicName MiddleName string `json:"-"` Lastname string `json:"lastName"` } type UserFilter struct { Name Country string `json:"country"` City string Scopes []string `json:"scopes"` Age *int `json:"age"` Height *float32 `json:"height"` } func main() { age := 42 filter := UserFilter{ Name: Name{ PublicName: PublicName{ First: "Max", }, MiddleName: "Gustav", Lastname: "Muster", }, Country: "Austria", City: "Vienna", Scopes: []string{"app", "user_info"}, Age: &age, } q := models.NewQuery( qm.Select("*"), qm.From("users"), db.WhereJSON("users", "profile", filter), ) sql, args := queries.BuildQuery(q) fmt.Println(sql) fmt.Print("[") for i := range args { if i < len(args)-1 { fmt.Printf("%v, ", args[i]) } else { fmt.Printf("%v", args[i]) } } fmt.Println("]") }
Output: SELECT * FROM "users" WHERE (users.profile->>'firstName' = $1 AND users.profile->>'lastName' = $2 AND users.profile->>'country' = $3 AND users.profile->'scopes' <@ to_jsonb($4::text[]) AND users.profile->>'age' = $5); [Max, Muster, Austria, &[app user_info], 42]
Types ¶
type OrderByNulls ¶
type OrderByNulls string
const ( OrderByNullsFirst OrderByNulls = "FIRST" OrderByNullsLast OrderByNulls = "LAST" )
type QueryMods ¶
QueryMods represents a slice of query mods, implementing the `queries.Applicator` interface to allow for usage with eager loading methods of models. Unfortunately, sqlboiler does not import the (identical) type used by the library, so we have to declare and "implemented" it ourselves...
type TxFn ¶
type TxFn func(boil.ContextExecutor) error