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
    }
相关推荐
江湖十年9 分钟前
在 Go 中如何使用有限状态机优雅解决程序中状态转换问题
后端·面试·go
无奈何杨13 分钟前
CoolGuard新增节假日和ApiKey管理
后端
天天摸鱼的java工程师18 分钟前
秒杀系统中:如何防止超卖和库存超扣?
java·后端
这里有鱼汤20 分钟前
1年10倍,全网都在说的尾盘选股法我用Python帮你们实现了
后端·python
CodeCipher26 分钟前
Java基础复习之继承
java·开发语言
IT_102426 分钟前
Spring Boot的Security安全控制——应用SpringSecurity!
大数据·spring boot·后端
DemonAvenger29 分钟前
Go微服务架构下内存优化策略
性能优化·架构·go
BillKu33 分钟前
Java延时
java·开发语言
寻月隐君33 分钟前
Solana 开发进阶:在 Devnet 上实现链上程序部署、调用与更新
后端·web3·区块链
Baihai_IDP39 分钟前
AI 智能体到底应该如何构建?分享 Github 上收获 4k stars 的 12 条原则
人工智能·后端·llm