Golang:在准备好的语句中不能使用sql.NamedArg

时间:2020-08-05 00:49:08

标签: mysql sql go aurora

我有一个查询使用的是sql.DB中的NamedArgs,在构建时出现错误

cannot use args (type []sql.NamedArg) as type []interface {} in argument to stmt.Exec

SQL库中的示例显示了它的使用情况:

Example usage:
    db.ExecContext(ctx, `
     delete from Invoice
     where
     TimeCreated < @end
     and TimeCreated >= @start;`,
     sql.Named("start", startTime),
     sql.Named("end", endTime),
    )

唯一的区别是,我当前正在使用准备好的语句stmt,并在其上调用Exec方法。我使用值创建了一个NamedArg切片,并且使用了...扩展器。

res, err := stmt.Exec(args...)

当示例直接在代码中显示sql.Named()方法调用时,究竟是什么问题?为什么扩展切片无法正常工作?

1 个答案:

答案 0 :(得分:0)

这就是Go中将参数传递给可变参数函数的方式。您可以传递可以是任何类型的单个值,也可以传递其元素类型与可变参数的类型完全匹配的切片,然后跟随...

即您可以:

res, err := stmt.Exec(
    sql.Named("start", startTime),
    sql.Named("end", endTime),
)

或者您可以这样做:

args := []interface{}{
    sql.Named("start", startTime),
    sql.Named("end", endTime),
}
res, err := stmt.Exec(args...)