登录
首页 >  Golang >  Go问答

Golang:sql.NamedArg 不能用于准备语句

来源:stackoverflow

时间:2024-03-26 16:15:32 367浏览 收藏

在使用 Go 语言的 `sql.NamedArg` 时,如果要将其用于准备好的语句,则不能直接使用 `...` 扩展器将切片传递给 `stmt.Exec` 方法。相反,需要将 `sql.NamedArg` 值转换为 `[]interface{}` 类型,然后才能将它们传递给 `stmt.Exec`。

问题内容

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


解决方案


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

今天关于《Golang:sql.NamedArg 不能用于准备语句》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>