Documentation ¶
Index ¶
Examples ¶
Constants ¶
This section is empty.
Variables ¶
View Source
var (
Dialect dialect
)
Functions ¶
This section is empty.
Types ¶
type DeleteModApply ¶
type DeleteModApply = sq.QueryModApply[tag.DeleteTag]
type DeleteQuery ¶
func Delete ¶
func Delete(mods ...DeleteMod) DeleteQuery
type InsertModApply ¶
type InsertModApply = sq.QueryModApply[tag.InsertTag]
type InsertQuery ¶
func Insert ¶
func Insert(mods ...InsertMod) InsertQuery
type SelectModApply ¶
type SelectModApply = sq.QueryModApply[tag.SelectTag]
type SelectQuery ¶
func Select ¶
func Select(mods ...SelectMod) SelectQuery
Example (LiteralSimple) ¶
package main import ( "fmt" "github.com/rrgmc/litsql/dialect/psql" "github.com/rrgmc/litsql/dialect/psql/sm" "github.com/rrgmc/litsql/sq" ) func main() { // SELECT q := psql.Select( // u.id, u.name sm.Columns("u.id", "u.name"), // , u.created_at, u.updated_at sm.Columns("u.created_at", "u.updated_at"), // FROM users As u sm.From("users AS u"), // WHERE u.age > 40 sm.Where("u.age > 40"), // AND u.deleted_at IS NOT NULL sm.Where("u.deleted_at IS NOT NULL"), // ORDER BY u.name ASC, u.age DESC sm.OrderBy("u.name ASC", "u.age DESC"), ) qs, _, err := sq.Build(q) if err != nil { panic(err) } fmt.Println(qs) }
Output: SELECT u.id, u.name, u.created_at, u.updated_at FROM users AS u WHERE u.age > 40 AND u.deleted_at IS NOT NULL ORDER BY u.name ASC, u.age DESC
Example (LiteralSimpleInvalid) ¶
package main import ( "fmt" "github.com/rrgmc/litsql/dialect/psql" "github.com/rrgmc/litsql/dialect/psql/sm" "github.com/rrgmc/litsql/sq" ) func main() { // the library won't prevent invalid SQL from being generated, like when using raw string. // SELECT q := psql.Select( // u.id, u.name of user sm.Columns("u.id", "u.name of user"), // FROM users AND NOT users sm.From("users AND NOT users"), // WHERE CREATE TABLE users sm.Where("CREATE TABLE users"), ) qs, _, err := sq.Build(q) if err != nil { panic(err) } fmt.Println(qs) }
Output: SELECT u.id, u.name of user FROM users AND NOT users WHERE CREATE TABLE users
type UpdateModApply ¶
type UpdateModApply = sq.QueryModApply[tag.UpdateTag]
type UpdateQuery ¶
func Update ¶
func Update(mods ...UpdateMod) UpdateQuery
Click to show internal directories.
Click to hide internal directories.