素のSQLを実行する
素のSQLを実行します。これは他のメソッドとつなげることはできません。
db.Exec("DROP TABLE users;") db.Exec("UPDATE orders SET shipped_at=? WHERE id IN (?)", time.Now(), []int64{11,22,33})
type Result struct { Name string Age int }
var result Result db.Raw("SELECT name, age FROM users WHERE name = ?", 3).Scan(&result)
|
sql.Row
& sql.Rows
クエリ結果を*sql.Row
や*sql.Rows
として取得します
row := db.Table("users").Where("name = ?", "jinzhu").Select("name, age").Row() row.Scan(&name, &age)
rows, err := db.Model(&User{}).Where("name = ?", "jinzhu").Select("name, age, email").Rows() defer rows.Close() for rows.Next() { ... rows.Scan(&name, &age, &email) ... }
rows, err := db.Raw("select name, age, email from users where name = ?", "jinzhu").Rows() defer rows.Close() for rows.Next() { ... rows.Scan(&name, &age, &email) ... }
|
sql.Rows
をモデルに変換します
rows, err := db.Model(&User{}).Where("name = ?", "jinzhu").Select("name, age, email").Rows() defer rows.Close()
for rows.Next() { var user User db.ScanRows(rows, &user)
}
|