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()) // 打印相应的更新条数
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。
