From d6c23586ae435a124353d3c5dfa6f504c24c5c3c Mon Sep 17 00:00:00 2001 From: Jinzhu Date: Fri, 5 Mar 2021 19:42:54 +0800 Subject: [PATCH] Revert "Don't override the from clauses, close #4129" close #4139 This reverts commit 664755270ddba77cc669de814afca71ae5575fce. --- callbacks/query.go | 5 ----- tests/sql_builder_test.go | 45 --------------------------------------- 2 files changed, 50 deletions(-) diff --git a/callbacks/query.go b/callbacks/query.go index aaa19c03..658216df 100644 --- a/callbacks/query.go +++ b/callbacks/query.go @@ -104,11 +104,6 @@ func BuildQuerySQL(db *gorm.DB) { } joins := []clause.Join{} - - if fromClause, ok := db.Statement.Clauses["FROM"].Expression.(clause.From); ok { - joins = fromClause.Joins - } - for _, join := range db.Statement.Joins { if db.Statement.Schema == nil { joins = append(joins, clause.Join{ diff --git a/tests/sql_builder_test.go b/tests/sql_builder_test.go index 081b96c9..acb08130 100644 --- a/tests/sql_builder_test.go +++ b/tests/sql_builder_test.go @@ -6,7 +6,6 @@ import ( "testing" "gorm.io/gorm" - "gorm.io/gorm/clause" . "gorm.io/gorm/utils/tests" ) @@ -243,47 +242,3 @@ func TestCombineStringConditions(t *testing.T) { t.Fatalf("invalid sql generated, got %v", sql) } } - -func TestFromWithJoins(t *testing.T) { - var result User - - newDB := DB.Session(&gorm.Session{NewDB: true, DryRun: true}).Table("users") - - newDB.Clauses( - clause.From{ - Tables: []clause.Table{{Name: "users"}}, - Joins: []clause.Join{ - { - Table: clause.Table{Name: "companies", Raw: false}, - ON: clause.Where{ - Exprs: []clause.Expression{ - clause.Eq{ - Column: clause.Column{ - Table: "users", - Name: "company_id", - }, - Value: clause.Column{ - Table: "companies", - Name: "id", - }, - }, - }, - }, - }, - }, - }, - ) - - newDB.Joins("inner join rgs on rgs.id = user.id") - - stmt := newDB.First(&result).Statement - str := stmt.SQL.String() - - if !strings.Contains(str, "rgs.id = user.id") { - t.Errorf("The second join condition is over written instead of combining") - } - - if !strings.Contains(str, "`users`.`company_id` = `companies`.`id`") && !strings.Contains(str, "\"users\".\"company_id\" = \"companies\".\"id\"") { - t.Errorf("The first join condition is over written instead of combining") - } -}