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
    }
相关推荐
hie988941 分钟前
MATLAB中进行语音信号分析
开发语言·matlab·语音识别
前进的程序员16 分钟前
C++经典库介绍
开发语言·c++
heart000_132 分钟前
Go 语言云原生微服务全栈实战:Docker 镜像优化、K8s 编排与 Istio 流量治理
微服务·云原生·golang
(・Д・)ノ1 小时前
python打卡day31
开发语言·人工智能·python
北漂老男孩1 小时前
JavaScript 性能优化实战指南
开发语言·javascript·性能优化
yorushika_1 小时前
python打卡训练营打卡记录day31
开发语言·python·机器学习
qq_2518364571 小时前
基于springboot3 VUE3 火车订票系统前后端分离项目适合新手学习的项目包含 智能客服 换乘算法
java·开发语言·spring boot·后端·学习
supingemail1 小时前
Spring Boot 的高级特性与经典的设计模式应用
spring boot·后端·设计模式
oioihoii1 小时前
C++23:修正常量迭代器、哨兵和范围
java·开发语言·c++23