相关文章推荐
宽容的刺猬  ·  Jquery ...·  1 月前    · 
安静的墨镜  ·  「R」apply,lapply,sapply ...·  1 年前    · 

golang sql converting argument $1 type unsupported type interface a slice of interface

sql 执行 exec源码

// Exec executes a prepared statement with the given arguments and
// returns a Result summarizing the effect of the statement.
func (s *Stmt) Exec(args ...interface{}) (Result, error) {
	return s.ExecContext(context.Background(), args...)

调用exec正确代码

//操作数据 ,
func OperateSql(insertSql string, execMsg  map[int][]interface{}, Db *sqlx.DB) error {
	mt, err := Db.Prepare(insertSql)
	CheckError(err)
	for index := range execMsg {
		msg := execMsg[index]
		res, err := mt.Exec(msg...)//引用exec
		CheckError(err)
	return err

字面意思是sqlx在解析两个占位符并试图填入参数时,第一个参数类型是空指针的切片,而预期是args这个可变参数中的第一个。因而了解了一下golang中的可变参数,即…运算符
当…Type做为参数时,本质上函数会把参数转化成一个Type类型的切片,因而在上述代码中,Service层调以可变参数形式传入一个参数,在Exec中的args就已经是[]interface{}类型了,若是直接把args做为func (s *Stmt) Exec args …interface{}) (Result, error)的参数,对于Exec来讲,收到的args就只有一个长度为1的切片,其元素类型为[]interface{},因而就有了上述的报错,解决办法很简单,就是在一个slice后加上…,这样就能把它拆包成一个可变参数的形式传入函数。

	res, err := mt.Exec(msg...)//正确引用exec
	res, err := mt.Exec(msg)//错误引用exec
        wangfengflyj