gpt4 book ai didi

SQL插入接口(interface) slice

转载 作者:行者123 更新时间:2023-12-01 20:26:44 25 4
gpt4 key购买 nike

我正在编写一个向 SQLite 数据库添加一行的函数。

func ManageDB(db *sqlx.DB, query string, args ...interface{}) (int64, error) {

stmt, err := db.Prepare(query)
if err != nil {
return -1, err
}
defer stmt.Close()

tx, err := db.Begin()
if err != nil {
return -1, err
}
_, err = tx.Stmt(stmt).Exec(args...)
if err != nil {
log.Errorf("error inserting row '%s' %v", query, err)
log.Debugln("Doing rollback on Insert")
tx.Rollback()
} else {
tx.Commit()
}

return res.LastInsertId()
}


我用那个来称呼它

b := "INSERT INTO MYTABLE (name1, name2, name3, name4) VALUES($1, $2, $3, $4)"

c := []interface{}{
"string1",
"string2",
0, // int64
"string4", //string4
}

idt, err := models.ManageDB(
db, //db initialized
b,
c,
)

.......


当我测试该功能时,它可以正常工作,并且可以毫无问题地添加项目。

当我在主代码上运行它时,它会报告此错误:

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



我不明白出了什么问题。

最佳答案

在第二个片段中,您没有传播 c在参数上,您只是传递 c .因此在 ManageDB , args等于:

[]interface{}{
[]interface{}{
"string1",
"string2",
0,
"string4",
}
}
等等 sqlx认为你想要 $1成为整个数组。
解决方法是调用 ManageDB像这样:
models.ManageDB(db, b, c...) 

关于SQL插入接口(interface) slice ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61160296/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com