Golang:不能使用sql.NamedArg在准备好的声明中



我有一个使用sql中NamedArgs的查询。DB和我在构建时出错

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()方法调用时,到底出了什么问题?为什么扩展切片不起作用?

这就是在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...)

最新更新