Go希望这个SQL查询中的第二个参数是什么.

stmt, err := db.Prepare("SELECT * FROM awesome_table WHERE id= $1 AND other_field IN $2")
rows, err := stmt.Query(10, ???)

我真正想要的是:

SELECT * FROM awesome_table WHERE id=10 AND other_field IN (this, that);

推荐答案

查询只需要varargs来替换sql中的参数

rows, err := stmt.Query(10)

比如说,你的第二个例子的这个和那个都是动态的,那么你会这样做

stmt, err := db.Prepare("SELECT * FROM awesome_table WHERE id=$1 AND other_field IN ($2, $3)")
rows, err := stmt.Query(10,"this","that")

如果"IN"部分有变量args,则可以执行(play)

package main

import "fmt"
import "strings"

func main() {
    stuff := []interface{}{"this", "that", "otherthing"}
    sql := "select * from foo where id=? and name in (?" + strings.Repeat(",?", len(stuff)-1) + ")"
    fmt.Println("SQL:", sql)
    args := []interface{}{10}
    args = append(args, stuff...)
    fakeExec(args...)
    // This also works, but I think it's harder for folks to read
    //fakeExec(append([]interface{}{10},stuff...)...)
}

func fakeExec(args ...interface{}) {
    fmt.Println("Got:", args)
}

Sql相关问答推荐

调用存储过程时SQL服务器TDS协议响应问题

SQL:创建查询以添加减少的总数

获取每5分钟时间间隔的总和

Postgres,使用iLike运算符从json数组中搜索的工作方式与从常规表中搜索不同

分组多输出访问查询问题

导出部分条形码字符串GS1-128

将日期时间转换为日期格式

如果另一个表中不存在值列,则插入失败

违反了完整性约束-值存在时找不到父键

如何使用SQL生成数据的滚动3天总和

通过UPDATE SELECT更新表时出现问题

Athena 计算从日期到当前时间戳的每月计数

替换SQL Server XML中多处出现的 node 值

如何在Hive SQL中分别按多列进行分组?

Postgres存在限制问题「小值」

BigQuery数组是否包含NULL值的判断方法

SQL Server: 将JSON对象数组转换为表格格式

PostgreSQL - 从同一张表中获取值

编写查询以根据级别 (p2) 返回父位置

SQL 计数和过滤查询优化