360dnsgormRowsAffected()返回0的问题亚布力滑雪场
理想流沙河
在项⽬中,经常需要更新数据,并且要获取到更新的条数从⽽做不同的操作。在gorm中提供了RowsAffected()的⽅法获取更新的条数。但是我们执⾏⼀下的代码会发现这个⽅法总是输出0,⼀点都不好使。
db := DBagent.DB.Table("ur_tab")
err := db.Where( "id = ?", 1).Updates(updateInfo).Error()绿的音节
青紫蓝println(db.RowsAffected()) // 总是打印0
我们的快乐生活
这是因为gorm中,如Find,Create,Update等⽅法⼀旦被调⽤后会马上跟数据库进⾏交互然后改变数据,并且会返回⼀个db对象,该对象中会有实际的rowsAffected等数据。因此应该这么使⽤RowsAffected()⽅法:
db := DBagent.DB.Table("ur_tab")
船舶db = db.Where( "id = ?", 1).Updates(updateInfo) // 此处获取到的db对象就包含相应的值
err := db.Error()
示波器的使用方法println(db.RowsAffected()) // 打印相应的更新条数