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) {
|
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 {
|
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 {
|
func (s *DB) Save(value interface{}) *DB {
|
||||||
scope := s.clone().NewScope(value)
|
scope := s.clone().NewScope(value)
|
||||||
|
var result *DB
|
||||||
if scope.PrimaryKeyZero() {
|
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 {
|
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 {
|
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 {
|
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 {
|
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 := scope.buildWhereCondition(map[string]interface{}{"query": sql, "args": values})
|
||||||
generatedSql = strings.TrimSuffix(strings.TrimPrefix(generatedSql, "("), ")")
|
generatedSql = strings.TrimSuffix(strings.TrimPrefix(generatedSql, "("), ")")
|
||||||
scope.Raw(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 {
|
func (s *DB) Model(value interface{}) *DB {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user