Skip to content

Latest commit

 

History

History
81 lines (69 loc) · 1.77 KB

README.md

File metadata and controls

81 lines (69 loc) · 1.77 KB

Sqlcomposer

Build SQL by YAML configure, Separating the code and sql

Features

  • Base on sqlx
  • Support filter pipeline
  • Support custom tokens
  • Fast build a service for sql base analysis

Examples

YAML Configure

info:
  name: example
  version: 1.0.0
composition:
  tokens:
    attrs:
      params:
        - name: prod-weight
          value: product_weight
        - name: prod-material
          value: product_material
  fields:
    base:
      - name: name
        expr: users.name
      - name: age
        expr: users.age
      - name: order_status
        expr: orders.status
    statistic:
      - name: consume_times
        expr: COUNT(orders.id)
      - name: consume_total
        expr: SUM(orders.total_amount)
  defaultConditions:
    - attr: users.name
      op: contains
      val: Barry
    - attr: order_status
      op: in
      val: [4,5,6,8]
  subject: 
    list: "SELECT %fields.base, %fields.statistic, %attrs FROM users LEFT JOIN orders ON orders.uid = users.uid %where GROUP BY users.uid %limit"
    total: "SELECT count(users.uid) FROM users LEFT JOIN order ON order.uid = users.uid %where GROUP BY users.uid"`

Golang Code to handler, get 'query' and 'args'

sb, err := NewSqlBuilder(db, []byte(sqlComposition))
if err != nil {
    t.Fatal(err)
}
// register custom token
err = sb.RegisterToken("attrs", func(params []TokenParam) TokenReplacer {
    attrs := map[string]string{}
    for _, p := range params {
        attrs[p.Name] = p.Value
    }

    return &attrsFieldsTokenReplacer{
        Attrs: attrs,
    }
})

err = sb.AddFilters([]Filter{
    {Val: "barry", Op: Contains, Attr: "users.name"},
    {Val: []int{1, 2, 4, 8}, Op: In, Attr: "order_status"},
}, AND)

q, args, err := sb.Rebind("list")

rows, err := db.Queryx(q, args)
...