Don't merge clause From

This commit is contained in:
Jinzhu 2020-07-15 10:25:10 +08:00
parent 1f05cb7e55
commit 72a64bef11
2 changed files with 11 additions and 15 deletions

View File

@ -33,9 +33,5 @@ func (from From) Build(builder Builder) {
// MergeClause merge from clause // MergeClause merge from clause
func (from From) MergeClause(clause *Clause) { func (from From) MergeClause(clause *Clause) {
if v, ok := clause.Expression.(From); ok {
from.Tables = append(v.Tables, from.Tables...)
from.Joins = append(v.Joins, from.Joins...)
}
clause.Expression = from clause.Expression = from
} }

View File

@ -38,6 +38,16 @@ func TestFrom(t *testing.T) {
[]clause.Interface{ []clause.Interface{
clause.Select{}, clause.From{ clause.Select{}, clause.From{
Tables: []clause.Table{{Name: "users"}}, Tables: []clause.Table{{Name: "users"}},
Joins: []clause.Join{
{
Type: clause.RightJoin,
Table: clause.Table{Name: "profiles"},
ON: clause.Where{
[]clause.Expression{clause.Eq{clause.Column{Table: "profiles", Name: "email"}, clause.Column{Table: clause.CurrentTable, Name: "email"}}},
},
},
},
}, clause.From{
Joins: []clause.Join{ Joins: []clause.Join{
{ {
Type: clause.InnerJoin, Type: clause.InnerJoin,
@ -51,19 +61,9 @@ func TestFrom(t *testing.T) {
Using: []string{"company_name"}, Using: []string{"company_name"},
}, },
}, },
}, clause.From{
Joins: []clause.Join{
{
Type: clause.RightJoin,
Table: clause.Table{Name: "profiles"},
ON: clause.Where{
[]clause.Expression{clause.Eq{clause.Column{Table: "profiles", Name: "email"}, clause.Column{Table: clause.CurrentTable, Name: "email"}}},
}, },
}, },
}, "SELECT * FROM `users` INNER JOIN `articles` ON `articles`.`id` = `users`.`id` LEFT JOIN `companies` USING (`company_name`)", nil,
},
},
"SELECT * FROM `users` INNER JOIN `articles` ON `articles`.`id` = `users`.`id` LEFT JOIN `companies` USING (`company_name`) RIGHT JOIN `profiles` ON `profiles`.`email` = `users`.`email`", nil,
}, },
} }