Skip to content

Commit

Permalink
Add SelectAttrs, OmitAttrs
Browse files Browse the repository at this point in the history
  • Loading branch information
jinzhu committed Mar 12, 2015
1 parent 94adc3e commit da7830e
Show file tree
Hide file tree
Showing 4 changed files with 28 additions and 9 deletions.
2 changes: 1 addition & 1 deletion main.go
Original file line number Diff line number Diff line change
Expand Up @@ -152,7 +152,7 @@ func (s *DB) Order(value string, reorder ...bool) *DB {
}

func (s *DB) Select(query interface{}, args ...interface{}) *DB {
return s.clone().search.Selects(query, args...).db
return s.clone().search.Select(query, args...).db
}

func (s *DB) Group(query string) *DB {
Expand Down
4 changes: 2 additions & 2 deletions scope_private.go
Original file line number Diff line number Diff line change
Expand Up @@ -358,7 +358,7 @@ func (scope *Scope) initialize() *Scope {

func (scope *Scope) pluck(column string, value interface{}) *Scope {
dest := reflect.Indirect(reflect.ValueOf(value))
scope.Search.Selects(column)
scope.Search.Select(column)
if dest.Kind() != reflect.Slice {
scope.Err(errors.New("results should be a slice"))
return scope
Expand All @@ -377,7 +377,7 @@ func (scope *Scope) pluck(column string, value interface{}) *Scope {
}

func (scope *Scope) count(value interface{}) *Scope {
scope.Search.Selects("count(*)")
scope.Search.Select("count(*)")
scope.Err(scope.row().Scan(value))
return scope
}
Expand Down
25 changes: 22 additions & 3 deletions search.go
Original file line number Diff line number Diff line change
Expand Up @@ -11,15 +11,16 @@ type search struct {
initAttrs []interface{}
assignAttrs []interface{}
selects map[string]interface{}
omits []string
orders []string
joins string
preload map[string][]interface{}
offset string
limit string
group string
tableName string
Unscoped bool
raw bool
Unscoped bool
}

func (s *search) clone() *search {
Expand All @@ -32,14 +33,15 @@ func (s *search) clone() *search {
initAttrs: s.initAttrs,
assignAttrs: s.assignAttrs,
selects: s.selects,
omits: s.omits,
orders: s.orders,
joins: s.joins,
offset: s.offset,
limit: s.limit,
group: s.group,
tableName: s.tableName,
Unscoped: s.Unscoped,
raw: s.raw,
Unscoped: s.Unscoped,
}
}

Expand Down Expand Up @@ -77,11 +79,28 @@ func (s *search) Order(value string, reorder ...bool) *search {
return s
}

func (s *search) Selects(query interface{}, args ...interface{}) *search {
func (s *search) Select(query interface{}, args ...interface{}) *search {
s.selects = map[string]interface{}{"query": query, "args": args}
return s
}

func (s *search) Omit(columns ...string) *search {
s.omits = columns
return s
}

func (s *search) SelectAttrs() (attrs []string) {
for key, value := range s.selects {
attrs = append(attrs, key)
attrs = append(attrs, value.([]string)...)
}
return attrs
}

func (s *search) OmitAttrs() []string {
return s.omits
}

func (s *search) Limit(value interface{}) *search {
s.limit = s.getInterfaceAsSql(value)
return s
Expand Down
6 changes: 3 additions & 3 deletions search_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,10 +7,10 @@ import (

func TestCloneSearch(t *testing.T) {
s := new(search)
s.Where("name = ?", "jinzhu").Order("name").Attrs("name", "jinzhu").Selects("name, age")
s.Where("name = ?", "jinzhu").Order("name").Attrs("name", "jinzhu").Select("name, age")

s1 := s.clone()
s1.Where("age = ?", 20).Order("age").Attrs("email", "a@e.org").Selects("email")
s1.Where("age = ?", 20).Order("age").Attrs("email", "a@e.org").Select("email")

if reflect.DeepEqual(s.whereConditions, s1.whereConditions) {
t.Errorf("Where should be copied")
Expand All @@ -24,7 +24,7 @@ func TestCloneSearch(t *testing.T) {
t.Errorf("InitAttrs should be copied")
}

if reflect.DeepEqual(s.Selects, s1.Selects) {
if reflect.DeepEqual(s.Select, s1.Select) {
t.Errorf("selectStr should be copied")
}
}

0 comments on commit da7830e

Please sign in to comment.