fix: save not use soft_delete (#4897)
* fix: Save not use soft_delete * fix: save not use soft_delete * fix: save not use soft_delete * fix: save not use soft_delete Co-authored-by: kinggo <>
This commit is contained in:
		
							parent
							
								
									300a23fc31
								
							
						
					
					
						commit
						e5bdd610c3
					
				| @ -57,7 +57,7 @@ func Create(config *Config) func(db *gorm.DB) { | |||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		if db.Statement.SQL.String() == "" { | 		if db.Statement.SQL.Len() == 0 { | ||||||
| 			db.Statement.SQL.Grow(180) | 			db.Statement.SQL.Grow(180) | ||||||
| 			db.Statement.AddClauseIfNotExists(clause.Insert{}) | 			db.Statement.AddClauseIfNotExists(clause.Insert{}) | ||||||
| 			db.Statement.AddClause(ConvertToCreateValues(db.Statement)) | 			db.Statement.AddClause(ConvertToCreateValues(db.Statement)) | ||||||
|  | |||||||
| @ -118,13 +118,7 @@ func Delete(config *Config) func(db *gorm.DB) { | |||||||
| 			return | 			return | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		if db.Statement.Schema != nil && !db.Statement.Unscoped { | 		if db.Statement.SQL.Len() == 0 { | ||||||
| 			for _, c := range db.Statement.Schema.DeleteClauses { |  | ||||||
| 				db.Statement.AddClause(c) |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		if db.Statement.SQL.String() == "" { |  | ||||||
| 			db.Statement.SQL.Grow(100) | 			db.Statement.SQL.Grow(100) | ||||||
| 			db.Statement.AddClauseIfNotExists(clause.Delete{}) | 			db.Statement.AddClauseIfNotExists(clause.Delete{}) | ||||||
| 
 | 
 | ||||||
| @ -147,6 +141,15 @@ func Delete(config *Config) func(db *gorm.DB) { | |||||||
| 			} | 			} | ||||||
| 
 | 
 | ||||||
| 			db.Statement.AddClauseIfNotExists(clause.From{}) | 			db.Statement.AddClauseIfNotExists(clause.From{}) | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		if db.Statement.Schema != nil { | ||||||
|  | 			for _, c := range db.Statement.Schema.DeleteClauses { | ||||||
|  | 				db.Statement.AddClause(c) | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		if db.Statement.SQL.Len() == 0 { | ||||||
| 			db.Statement.Build(db.Statement.BuildClauses...) | 			db.Statement.Build(db.Statement.BuildClauses...) | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -33,7 +33,7 @@ func BuildQuerySQL(db *gorm.DB) { | |||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	if db.Statement.SQL.String() == "" { | 	if db.Statement.SQL.Len() == 0 { | ||||||
| 		db.Statement.SQL.Grow(100) | 		db.Statement.SQL.Grow(100) | ||||||
| 		clauseSelect := clause.Select{Distinct: db.Statement.Distinct} | 		clauseSelect := clause.Select{Distinct: db.Statement.Distinct} | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -59,13 +59,7 @@ func Update(config *Config) func(db *gorm.DB) { | |||||||
| 			return | 			return | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		if db.Statement.Schema != nil && !db.Statement.Unscoped { | 		if db.Statement.SQL.Len() == 0 { | ||||||
| 			for _, c := range db.Statement.Schema.UpdateClauses { |  | ||||||
| 				db.Statement.AddClause(c) |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		if db.Statement.SQL.String() == "" { |  | ||||||
| 			db.Statement.SQL.Grow(180) | 			db.Statement.SQL.Grow(180) | ||||||
| 			db.Statement.AddClauseIfNotExists(clause.Update{}) | 			db.Statement.AddClauseIfNotExists(clause.Update{}) | ||||||
| 			if set := ConvertToAssignments(db.Statement); len(set) != 0 { | 			if set := ConvertToAssignments(db.Statement); len(set) != 0 { | ||||||
| @ -73,6 +67,16 @@ func Update(config *Config) func(db *gorm.DB) { | |||||||
| 			} else if _, ok := db.Statement.Clauses["SET"]; !ok { | 			} else if _, ok := db.Statement.Clauses["SET"]; !ok { | ||||||
| 				return | 				return | ||||||
| 			} | 			} | ||||||
|  | 
 | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		if db.Statement.Schema != nil { | ||||||
|  | 			for _, c := range db.Statement.Schema.UpdateClauses { | ||||||
|  | 				db.Statement.AddClause(c) | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		if db.Statement.SQL.Len() == 0 { | ||||||
| 			db.Statement.Build(db.Statement.BuildClauses...) | 			db.Statement.Build(db.Statement.BuildClauses...) | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -103,7 +103,7 @@ func (sd SoftDeleteUpdateClause) MergeClause(*clause.Clause) { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func (sd SoftDeleteUpdateClause) ModifyStatement(stmt *Statement) { | func (sd SoftDeleteUpdateClause) ModifyStatement(stmt *Statement) { | ||||||
| 	if stmt.SQL.String() == "" { | 	if stmt.SQL.Len() == 0 && !stmt.Statement.Unscoped { | ||||||
| 		if _, ok := stmt.Clauses["WHERE"]; stmt.DB.AllowGlobalUpdate || ok { | 		if _, ok := stmt.Clauses["WHERE"]; stmt.DB.AllowGlobalUpdate || ok { | ||||||
| 			SoftDeleteQueryClause(sd).ModifyStatement(stmt) | 			SoftDeleteQueryClause(sd).ModifyStatement(stmt) | ||||||
| 		} | 		} | ||||||
| @ -129,7 +129,7 @@ func (sd SoftDeleteDeleteClause) MergeClause(*clause.Clause) { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func (sd SoftDeleteDeleteClause) ModifyStatement(stmt *Statement) { | func (sd SoftDeleteDeleteClause) ModifyStatement(stmt *Statement) { | ||||||
| 	if stmt.SQL.String() == "" { | 	if stmt.SQL.Len() == 0 && !stmt.Statement.Unscoped { | ||||||
| 		curTime := stmt.DB.NowFunc() | 		curTime := stmt.DB.NowFunc() | ||||||
| 		stmt.AddClause(clause.Set{{Column: clause.Column{Name: sd.Field.DBName}, Value: curTime}}) | 		stmt.AddClause(clause.Set{{Column: clause.Column{Name: sd.Field.DBName}, Value: curTime}}) | ||||||
| 		stmt.SetColumn(sd.Field.DBName, curTime, true) | 		stmt.SetColumn(sd.Field.DBName, curTime, true) | ||||||
|  | |||||||
| @ -645,7 +645,13 @@ func TestSave(t *testing.T) { | |||||||
| 
 | 
 | ||||||
| 	dryDB := DB.Session(&gorm.Session{DryRun: true}) | 	dryDB := DB.Session(&gorm.Session{DryRun: true}) | ||||||
| 	stmt := dryDB.Save(&user).Statement | 	stmt := dryDB.Save(&user).Statement | ||||||
| 	if !regexp.MustCompile("WHERE .id. = [^ ]+$").MatchString(stmt.SQL.String()) { | 	if !regexp.MustCompile(`.id. = .* AND .users.\..deleted_at. IS NULL`).MatchString(stmt.SQL.String()) { | ||||||
|  | 		t.Fatalf("invalid updating SQL, got %v", stmt.SQL.String()) | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	dryDB = DB.Session(&gorm.Session{DryRun: true}) | ||||||
|  | 	stmt = dryDB.Unscoped().Save(&user).Statement | ||||||
|  | 	if !regexp.MustCompile(`WHERE .id. = [^ ]+$`).MatchString(stmt.SQL.String()) { | ||||||
| 		t.Fatalf("invalid updating SQL, got %v", stmt.SQL.String()) | 		t.Fatalf("invalid updating SQL, got %v", stmt.SQL.String()) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 kinggo
						kinggo