mysql - Golang:不能在准备好的语句中使用 sql.NamedArg
问题描述
我有一个使用 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...)
推荐阅读
- node.js - 如何保证最新的写入不会被先前的写入覆盖
- ssl - 无法“openssl 验证”letsencrypt 证书
- javascript - 在文本文件中使用 DOM 解析器
- javascript - 使用 JSON 创建 Bootstrap TreeView
- ios - 防止 UINavigationBar 在 UITableView 滚动 iOS 11 上增长
- javascript - decodeString:正则表达式解决方案
- angularjs - 验证所需的 ui-select 字段
- javascript - HTML 文本与方向 rtl 左对齐
- netlogo - 如何按标签查找海龟并获取其 WHO 值?
- javascript - MomentJS isAfter 在包含天数时不起作用