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