Java转Go日记(四十四):Sql构建

1.1.1. 执行原生SQL

复制代码
    db.Exec("DROP TABLE users;")
    db.Exec("UPDATE orders SET shipped_at=? WHERE id IN (?)", time.Now, []int64{11,22,33})

    // Scan
    type Result struct {
        Name string
        Age  int
    }

    var result Result
    db.Raw("SELECT name, age FROM users WHERE name = ?", 3).Scan(&result)

1.1.2. sql.Row & sql.Rows

获取查询结果为*sql.Row*sql.Rows

复制代码
    row := db.Table("users").Where("name = ?", "jinzhu").Select("name, age").Row() // (*sql.Row)
    row.Scan(&name, &age)

    rows, err := db.Model(&User{}).Where("name = ?", "jinzhu").Select("name, age, email").Rows() // (*sql.Rows, error)
    defer rows.Close()
    for rows.Next() {
        ...
        rows.Scan(&name, &age, &email)
        ...
    }

    // Raw SQL
    rows, err := db.Raw("select name, age, email from users where name = ?", "jinzhu").Rows() // (*sql.Rows, error)
    defer rows.Close()
    for rows.Next() {
        ...
        rows.Scan(&name, &age, &email)
        ...
    }

1.1.3. 迭代中使用sql.Rows的Scan

复制代码
    rows, err := db.Model(&User{}).Where("name = ?", "jinzhu").Select("name, age, email").Rows() // (*sql.Rows, error)
    defer rows.Close()

    for rows.Next() {
      var user User
      db.ScanRows(rows, &user)
      // do something
    }
相关推荐
咖啡の猫6 分钟前
bash的特性-常见的快捷键
开发语言·chrome·bash
命苦的孩子8 分钟前
Java 中的排序算法详解
java·开发语言·排序算法
咖啡の猫8 分钟前
bash的特性-常用的通配符
开发语言·chrome·bash
苏三说技术25 分钟前
千万级的大表如何新增字段?
后端
外滩运维专家28 分钟前
后端开发必备:生产环境异常自动电话通知方案
后端·程序员
绝无仅有35 分钟前
Redis 服务挂掉排查与解决
后端·面试·github
淮北49443 分钟前
STL学习(四、队列和堆栈)
开发语言·c++·学习
五岁小孩1 小时前
Go 原理之 GMP 并发调度模型
golang·gmp·并发调度模型
FSHOW1 小时前
重新造轮子?HestJS:让 Hono 拥有 NestJS 的优雅
前端·javascript·后端
惜.己1 小时前
pytest中使用ordering控制函数的执行顺序
开发语言·python·pytest