12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667 |
- // Copyright 2018 Huan Du. All rights reserved.
- // Licensed under the MIT license that can be found in the LICENSE file.
- package sqlbuilder
- import (
- "database/sql"
- "fmt"
- )
- func ExampleSelectBuilder() {
- sb := NewSelectBuilder()
- sb.Distinct().Select("id", "name", sb.As("COUNT(*)", "t"))
- sb.From("demo.user")
- sb.Where(
- sb.GreaterThan("id", 1234),
- sb.Like("name", "%Du"),
- sb.Or(
- sb.IsNull("id_card"),
- sb.In("status", 1, 2, 5),
- ),
- sb.NotIn(
- "id",
- NewSelectBuilder().Select("id").From("banned"),
- ), // Nested SELECT.
- "modified_at > created_at + "+sb.Var(86400), // It's allowed to write arbitrary SQL.
- )
- sb.GroupBy("status").Having(sb.NotIn("status", 4, 5))
- sb.OrderBy("modified_at").Asc()
- sb.Limit(10).Offset(5)
- sql, args := sb.Build()
- fmt.Println(sql)
- fmt.Println(args)
- // Output:
- // SELECT DISTINCT id, name, COUNT(*) AS t FROM demo.user WHERE id > ? AND name LIKE ? AND (id_card IS NULL OR status IN (?, ?, ?)) AND id NOT IN (SELECT id FROM banned) AND modified_at > created_at + ? GROUP BY status HAVING status NOT IN (?, ?) ORDER BY modified_at ASC LIMIT 10 OFFSET 5
- // [1234 %Du 1 2 5 86400 4 5]
- }
- func ExampleSelectBuilder_advancedUsage() {
- sb := NewSelectBuilder()
- innerSb := NewSelectBuilder()
- sb.Select("id", "name")
- sb.From(
- sb.BuilderAs(innerSb, "user"),
- )
- sb.Where(
- sb.In("status", Flatten([]int{1, 2, 3})...),
- sb.Between("created_at", sql.Named("start", 1234567890), sql.Named("end", 1234599999)),
- )
- innerSb.Select("*")
- innerSb.From("banned")
- innerSb.Where(
- innerSb.NotIn("name", Flatten([]string{"Huan Du", "Charmy Liu"})...),
- )
- sql, args := sb.Build()
- fmt.Println(sql)
- fmt.Println(args)
- // Output:
- // SELECT id, name FROM (SELECT * FROM banned WHERE name NOT IN (?, ?)) AS user WHERE status IN (?, ?, ?) AND created_at BETWEEN @start AND @end
- // [Huan Du Charmy Liu 1 2 3 {{} start 1234567890} {{} end 1234599999}]
- }
|