Golang:不能在准备好的语句中使用 sql.NamedArg
Golang: cannot use sql.NamedArg in prepared statement
我有一个使用 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...)
我有一个使用 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...)