Propagate error to the original DB
This commit is contained in:
parent
675bbca667
commit
173a2d44a8
27
main.go
27
main.go
@ -220,7 +220,11 @@ func (s *DB) Row() *sql.Row {
|
||||
}
|
||||
|
||||
func (s *DB) Rows() (*sql.Rows, error) {
|
||||
return s.NewScope(s.Value).rows()
|
||||
result, err := s.NewScope(s.Value).rows()
|
||||
if intf, ok := s.values["__orig"]; ok {
|
||||
intf.(*DB).Error = err
|
||||
}
|
||||
return result, err
|
||||
}
|
||||
|
||||
func (s *DB) Pluck(column string, value interface{}) *DB {
|
||||
@ -286,10 +290,14 @@ func (s *DB) UpdateColumns(values interface{}) *DB {
|
||||
|
||||
func (s *DB) Save(value interface{}) *DB {
|
||||
scope := s.clone().NewScope(value)
|
||||
var result *DB
|
||||
if scope.PrimaryKeyZero() {
|
||||
return scope.callCallbacks(s.parent.callback.creates).db
|
||||
result = scope.callCallbacks(s.parent.callback.creates).db
|
||||
} else {
|
||||
result = scope.callCallbacks(s.parent.callback.updates).db
|
||||
}
|
||||
return scope.callCallbacks(s.parent.callback.updates).db
|
||||
s.Error = result.Error
|
||||
return result
|
||||
}
|
||||
|
||||
func (s *DB) Create(value interface{}) *DB {
|
||||
@ -298,11 +306,16 @@ func (s *DB) Create(value interface{}) *DB {
|
||||
}
|
||||
|
||||
func (s *DB) Delete(value interface{}, where ...interface{}) *DB {
|
||||
return s.clone().NewScope(value).inlineCondition(where...).callCallbacks(s.parent.callback.deletes).db
|
||||
result := s.clone().NewScope(value).inlineCondition(where...).callCallbacks(s.parent.callback.deletes).db
|
||||
s.Error = result.Error
|
||||
return result
|
||||
}
|
||||
|
||||
func (s *DB) Raw(sql string, values ...interface{}) *DB {
|
||||
return s.clone().search.Raw(true).Where(sql, values...).db
|
||||
result := s.clone().search.Raw(true).Where(sql, values...).db
|
||||
result.values["__orig"] = s
|
||||
s.Error = result.Error
|
||||
return result
|
||||
}
|
||||
|
||||
func (s *DB) Exec(sql string, values ...interface{}) *DB {
|
||||
@ -310,7 +323,9 @@ func (s *DB) Exec(sql string, values ...interface{}) *DB {
|
||||
generatedSql := scope.buildWhereCondition(map[string]interface{}{"query": sql, "args": values})
|
||||
generatedSql = strings.TrimSuffix(strings.TrimPrefix(generatedSql, "("), ")")
|
||||
scope.Raw(generatedSql)
|
||||
return scope.Exec().db
|
||||
result := scope.Exec().db
|
||||
s.Error = result.Error
|
||||
return result
|
||||
}
|
||||
|
||||
func (s *DB) Model(value interface{}) *DB {
|
||||
|
Loading…
x
Reference in New Issue
Block a user