登录
首页 >  Golang >  Go问答

GORM 原始 sql 未执行

来源:stackoverflow

时间:2024-02-12 14:36:18 418浏览 收藏

学习知识要善于思考,思考,再思考!今天golang学习网小编就给大家带来《GORM 原始 sql 未执行》,以下内容主要包含等知识点,如果你正在学习或准备学习Golang,就都不要错过本文啦~让我们一起来看看吧,能帮助到你就更好了!

问题内容

我有一个简单的 update sql 语句,我正在尝试执行:

if err := gormDB.Raw("UPDATE orders SET item_id = ? WHERE client_id = ?", "item1", "client1").Error; err != nil {
    return err
}

没有返回错误,但我的查询似乎没有在数据库上执行。不会记录任何内容,也不会保留任何数据库更改。


正确答案


单独调用 raw 不会执行查询。执行操作并检索结果的一种方法是使用 rows() 方法:

if _, err := gormdb.raw("update orders set item_id = ? where client_id = ?", "item1", "client1").rows(); err != nil {
    return err
}
// parse rows...

但就我而言,我不需要访问返回的结果,因此我选择使用 exec 方法,该方法立即执行给定的 sql:

if err := gormDB.Exec("UPDATE orders SET item_id = ? WHERE client_id = ?", "item1", "client1").Error; err != nil {
    return err
}
  1. gormdb.raw() 将返回 (tx *db),它不会执行, 一般用于查询。
  2. 直接使用gormdb.exec()

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于Golang的相关知识,也可关注golang学习网公众号。

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>