Find

5.4.Find

Fetch multipe objects into a slice or a map, use Find

  1. var everyone []Userinfo
  2. err := engine.Find(&everyone)
  3. users := make(map[int64]Userinfo)
  4. err := engine.Find(&users)
  • Also you can use Where, Limit
  1. var allusers []Userinfo
  2. err := engine.Where("id > ?", "3").Limit(10,20).Find(&allusers) //Get id>3 limit 10 offset 20
  • or you can use a struct query
  1. var tenusers []Userinfo
  2. err := engine.Limit(10).Find(&tenusers, &Userinfo{Name:"xlw"}) //Get All Name="xlw" limit 10 offset 0
  • or In function
  1. var tenusers []Userinfo
  2. err := engine.In("id", 1, 3, 5).Find(&tenusers) //Get All id in (1, 3, 5)
  • The default will query all columns of a table. Use Cols function if you want to select some columns
  1. var tenusers []Userinfo
  2. err := engine.Cols("id", "name").Find(&tenusers) //Find only id and name
  • You can also use slice of ints if you only want one column
  1. var ints []int64
  2. err := engine.Table("user").Cols("id").Find(&ints)