gorm RowsAffected()返回0的问题及解决
更新时间:2025年12月31日 09:31:59 作者:我一个搬砖人
在gorm中,`RowsAffected()`方法用于获取更新操作的受影响行数,如果在执行更新操作后立即调用`RowsAffected()`,可能会得到0,因为该方法在内部已经执行了数据库操作并更新了数据,正确的使用方法是在执行更新操作后,通过返回的`db`对象来获取受影响的行数
gorm RowsAffected()返回0
在项目中
经常需要更新数据,并且要获取到更新的条数从而做不同的操作。
在gorm中提供了RowsAffected()的方法获取更新的条数。
但是我们执行一下的代码会发现这个方法总是输出0,一点都不好使。
db := DBagent.DB.Table("user_tab")
err := db.Where( "id = ?", 1).Updates(updateInfo).Error()
println(db.RowsAffected()) // 总是打印0这是因为gorm中,如Find,Create,Update等方法一旦被调用后会马上跟数据库进行交互然后改变数据,并且会返回一个db对象,该对象中会有实际的rowsAffected等数据。
应该这么使用RowsAffected()方法
db := DBagent.DB.Table("user_tab")
db = db.Where( "id = ?", 1).Updates(updateInfo) // 此处获取到的db对象就包含相应的值
err := db.Error()
println(db.RowsAffected()) // 打印相应的更新条数总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
golang jsoniter extension 处理动态字段的实现方法
这篇文章主要介绍了golang jsoniter extension 处理动态字段的实现方法,我们使用实例级别的 extension, 而非全局,可以针对不同业务逻辑有所区分,jsoniter 包提供了比较完善的定制能力,通过例子可以感受一下扩展性,需要的朋友可以参考下2023-04-04
Golang利用compress/flate包来压缩和解压数据
在处理需要高效存储和快速传输的数据时,数据压缩成为了一项不可或缺的技术,Go语言的compress/flate包为我们提供了对DEFLATE压缩格式的原生支持,本文将深入探讨compress/flate包的使用方法,揭示如何利用它来压缩和解压数据,并提供实际的代码示例,需要的朋友可以参考下2024-08-08
关于go-zero单体服务使用泛型简化注册Handler路由的问题
这篇文章主要介绍了go-zero单体服务使用泛型简化注册Handler路由,涉及到Golang环境安装及配置Go Module的相关知识,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2022-07-07


最新评论