86 lines
2.1 KiB
Go
86 lines
2.1 KiB
Go
// Copyright 2019 The Xorm Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package builder
|
|
|
|
import (
|
|
"fmt"
|
|
)
|
|
|
|
// InnerJoin sets inner join
|
|
func (b *Builder) InnerJoin(joinTable, joinCond interface{}) *Builder {
|
|
return b.Join("INNER", joinTable, joinCond)
|
|
}
|
|
|
|
// LeftJoin sets left join SQL
|
|
func (b *Builder) LeftJoin(joinTable, joinCond interface{}) *Builder {
|
|
return b.Join("LEFT", joinTable, joinCond)
|
|
}
|
|
|
|
// RightJoin sets right join SQL
|
|
func (b *Builder) RightJoin(joinTable, joinCond interface{}) *Builder {
|
|
return b.Join("RIGHT", joinTable, joinCond)
|
|
}
|
|
|
|
// CrossJoin sets cross join SQL
|
|
func (b *Builder) CrossJoin(joinTable, joinCond interface{}) *Builder {
|
|
return b.Join("CROSS", joinTable, joinCond)
|
|
}
|
|
|
|
// FullJoin sets full join SQL
|
|
func (b *Builder) FullJoin(joinTable, joinCond interface{}) *Builder {
|
|
return b.Join("FULL", joinTable, joinCond)
|
|
}
|
|
|
|
// Join sets join table and conditions
|
|
func (b *Builder) Join(joinType string, joinTable, joinCond interface{}) *Builder {
|
|
switch joinCond.(type) {
|
|
case Cond:
|
|
b.joins = append(b.joins, join{joinType, joinTable, joinCond.(Cond)})
|
|
case string:
|
|
b.joins = append(b.joins, join{joinType, joinTable, Expr(joinCond.(string))})
|
|
}
|
|
|
|
return b
|
|
}
|
|
|
|
type joins []join
|
|
|
|
func (joins joins) WriteTo(w Writer) error {
|
|
for _, v := range joins {
|
|
var joinTable = v.joinTable
|
|
var alias string
|
|
if aliased, ok := v.joinTable.(*Aliased); ok {
|
|
joinTable = aliased.table
|
|
alias = aliased.alias + " "
|
|
}
|
|
|
|
switch tbl := joinTable.(type) {
|
|
case *Builder:
|
|
if _, err := fmt.Fprintf(w, " %s JOIN (", v.joinType); err != nil {
|
|
return err
|
|
}
|
|
if err := tbl.WriteTo(w); err != nil {
|
|
return err
|
|
}
|
|
if _, err := fmt.Fprintf(w, ") %s", alias); err != nil {
|
|
return err
|
|
}
|
|
case string:
|
|
if _, err := fmt.Fprintf(w, " %s JOIN %s %s", v.joinType, tbl, alias); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if _, err := fmt.Fprintf(w, "ON "); err != nil {
|
|
return err
|
|
}
|
|
|
|
if err := v.joinCond.WriteTo(w); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|