gorm RowsAffected()返回0的问题及解决
作者:我一个搬砖人
在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()) // 打印相应的更新条数总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
