95d91f17f3
* Added select and join querymod
69 lines
1.1 KiB
Go
69 lines
1.1 KiB
Go
package boil
|
|
|
|
type QueryMod func(q *Query)
|
|
|
|
func (q *Query) Apply(mods ...QueryMod) {
|
|
for _, mod := range mods {
|
|
mod(q)
|
|
}
|
|
}
|
|
|
|
func DB(e Executor) QueryMod {
|
|
return func(q *Query) {
|
|
q.executor = e
|
|
}
|
|
}
|
|
|
|
func Limit(limit int) QueryMod {
|
|
return func(q *Query) {
|
|
q.limit = limit
|
|
}
|
|
}
|
|
|
|
func Join(join string) QueryMod {
|
|
return func(q *Query) {
|
|
q.joins = append(q.joins, join)
|
|
}
|
|
}
|
|
|
|
func Select(columns ...string) QueryMod {
|
|
return func(q *Query) {
|
|
q.selectCols = append(q.selectCols, columns...)
|
|
}
|
|
}
|
|
|
|
func Where(clause string, args ...interface{}) QueryMod {
|
|
return func(q *Query) {
|
|
w := where{
|
|
clause: clause,
|
|
args: args,
|
|
}
|
|
|
|
q.where = append(q.where, w)
|
|
}
|
|
}
|
|
|
|
func GroupBy(clause string) QueryMod {
|
|
return func(q *Query) {
|
|
q.groupBy = append(q.groupBy, clause)
|
|
}
|
|
}
|
|
|
|
func OrderBy(clause string) QueryMod {
|
|
return func(q *Query) {
|
|
q.orderBy = append(q.orderBy, clause)
|
|
}
|
|
}
|
|
|
|
func Having(clause string) QueryMod {
|
|
return func(q *Query) {
|
|
q.having = append(q.having, clause)
|
|
}
|
|
}
|
|
|
|
func From(table string) QueryMod {
|
|
return func(q *Query) {
|
|
q.from = table
|
|
}
|
|
}
|