当前位置: 首页 > 工具软件 > gosql > 使用案例 >

go sql报错: converting argument $1 type: unsupported type []interface {}, a slice of interface

华煜祺
2023-12-01

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
 类似资料: