(terms ...interface{})
| 102 | } |
| 103 | |
| 104 | func (upd *updater) Set(terms ...interface{}) db.Updater { |
| 105 | return upd.frame(func(uq *updaterQuery) error { |
| 106 | if uq.columnValues == nil { |
| 107 | uq.columnValues = &exql.ColumnValues{} |
| 108 | } |
| 109 | |
| 110 | if len(terms) == 1 { |
| 111 | ff, vv, err := Map(terms[0], nil) |
| 112 | if err == nil && len(ff) > 0 { |
| 113 | cvs := make([]exql.Fragment, 0, len(ff)) |
| 114 | args := make([]interface{}, 0, len(vv)) |
| 115 | |
| 116 | for i := range ff { |
| 117 | cv := &exql.ColumnValue{ |
| 118 | Column: exql.ColumnWithName(ff[i]), |
| 119 | Operator: upd.SQL().t.AssignmentOperator, |
| 120 | } |
| 121 | |
| 122 | var localArgs []interface{} |
| 123 | cv.Value, localArgs = upd.SQL().t.PlaceholderValue(vv[i]) |
| 124 | |
| 125 | args = append(args, localArgs...) |
| 126 | cvs = append(cvs, cv) |
| 127 | } |
| 128 | |
| 129 | uq.columnValues.Insert(cvs...) |
| 130 | uq.columnValuesArgs = append(uq.columnValuesArgs, args...) |
| 131 | |
| 132 | return nil |
| 133 | } |
| 134 | } |
| 135 | |
| 136 | cv, arguments := upd.SQL().t.setColumnValues(terms) |
| 137 | uq.columnValues.Insert(cv.ColumnValues...) |
| 138 | uq.columnValuesArgs = append(uq.columnValuesArgs, arguments...) |
| 139 | return nil |
| 140 | }) |
| 141 | } |
| 142 | |
| 143 | func (upd *updater) Amend(fn func(string) string) db.Updater { |
| 144 | return upd.frame(func(uq *updaterQuery) error { |
nothing calls this directly
no test coverage detected