douyinlai2169 2015-08-05 23:55
浏览 74
已采纳

如何设置隔离级别

I want to set isolation level to repeatable read. How do I achieve this using gorm orm for postgres.

Example code:

func CreateAnimals(db *gorm.DB) err {
  tx := db.Begin()
  // Note the use of tx as the database handle once you are within a transaction

  if err := tx.Create(&Animal{Name: "Giraffe"}).Error; err != nil {
     tx.Rollback()
     return err
  }

  if err := tx.Create(&Animal{Name: "Lion"}).Error; err != nil {
     tx.Rollback()
     return err
  }

  tx.Commit()
  return nil
}
  • 写回答

1条回答 默认 最新

  • dongyi5817 2015-08-06 00:43
    关注

    I had exactly the same problem here:

    func GetPageAfterUpdate(dp model.DbProvider, id int, update int, page *Page) (err error) {
      tx := dp.DB().Begin()
    
      err = tx.Exec(`set transaction isolation level repeatable read`).Error
      if err != nil {
        tx.Rollback()
        return
      }
    

    And it is exactly gorm with pg.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 关于#Java#的问题,如何解决?
  • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
  • ¥15 想问一下树莓派接上显示屏后出现如图所示画面,是什么问题导致的
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥15 cmd cl 0x000007b
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line
  • ¥500 火焰左右视图、视差(基于双目相机)
  • ¥100 set_link_state
  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化