本文整理汇总了Golang中github.com/jinzhu/gorm.DB.Scan方法的典型用法代码示例。如果您正苦于以下问题:Golang DB.Scan方法的具体用法?Golang DB.Scan怎么用?Golang DB.Scan使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类github.com/jinzhu/gorm.DB
的用法示例。
在下文中一共展示了DB.Scan方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Golang代码示例。
示例1: Query
func (d *sqlDatabase) Query(q query) ([]record, error) {
var rs []record
var ws []string
var ps []interface{}
if q.Cmd != nil {
ws = append(ws, "cmd LIKE ?")
ps = append(ps, "%"+*q.Cmd+"%")
}
if q.Dir != nil {
ws = append(ws, "dir = ?")
ps = append(ps, q.Dir)
}
if q.Hostname != nil {
ws = append(ws, "hostname = ?")
ps = append(ps, q.Hostname)
}
if q.ShellSessionID != nil {
ws = append(ws, "shell_session_id = ?")
ps = append(ps, q.ShellSessionID)
}
var db *gorm.DB
if q.SortByFreq {
db = d.db.Table("records").Select(sqlSelectByFreq).Where(strings.Join(ws, " and "), ps...).Group(sqlGroupByFreq).Order("c desc").Limit(q.Limit).Offset(q.Offset)
} else {
db = d.db.Table("records").Select(sqlSelectByDate).Where(strings.Join(ws, " and "), ps...).Order("time desc").Limit(q.Limit).Offset(q.Offset)
}
err := db.Scan(&rs).Error
return rs, err
}
示例2: NewRec
// NewRec returns a bool depending on whether or not it could find a record
func (db *DB) NewRec(table, field, data string) bool {
var d string
if isADate(data) {
t, err := time.Parse("2006-01-02 15:04:05 -0700 UTC", data)
if err != nil {
log.Fatalf("Problem parsing date: %s", err)
}
d = t.Format("2006-01-02 15:04:05")
}
var count int
f := fmt.Sprintf("%s = ?", field)
var row *gorm.DB
if isADate(data) {
row = db.Table(table).Where(f, d).Limit(1).Select(field).Count(&count)
} else {
row = db.Table(table).Where(f, data).Limit(1).Select(field).Count(&count)
}
row.Scan(&count)
if count == 0 {
return true
}
return false
}