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()当示例直接在代码中显示方法调用时,究竟出了什么问题?为什么扩展切片不起作用?


白衣非少年
浏览 195回答 1
1回答

海绵宝宝撒

这就是在 Go 中将参数传递给可变参数函数的工作原理。您要么传递可以是任何类型的单个值,要么传递一个元素类型与可变参数完全匹配的切片,并在其后面加上....即你可以这样做:res, err := stmt.Exec(&nbsp; &nbsp; sql.Named("start", startTime),&nbsp; &nbsp; sql.Named("end", endTime),)或者你可以这样做:args := []interface{}{&nbsp; &nbsp; sql.Named("start", startTime),&nbsp; &nbsp; sql.Named("end", endTime),}res, err := stmt.Exec(args...)
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Go