shbinyan 2021-02-16 20:23 采纳率: 50%
浏览 52
已采纳

请问下各位mysql和postgresql的事务开启机制啊

请问下啊,我在网上看到描述mysql事务的这样一段话:

If the transaction isolation level is REPEATABLE READ (the default

level), all consistent reads within the same transaction read the

snapshot established by the first such read in that transaction.

With READ COMMITTED isolation level, each consistent read within a transaction sets and reads its own fresh snapshot.

解释是在RR隔离级别下,执行start transaction命令后,并未开启事务,而是等到第一条语句执行时开启事务并建立一致性读的snapshot。原文地址:

https://blog.csdn.net/weixin_29596789/article/details/113146484

1. 我有点晕,这个所谓的第一条语句必须是select语句吗?

2. 而且是对限定条件的数据建立快照吗?原文里提到了such read,那是不是说第一条select语句如果查的是id=5的记录,那就只对这条语句执行前(而不是start transcation语句前)的1条记录建立快照吗?第2条select语句如果查的是id>5的记录,那就只对第2条语句执行前的id>5的记录建立快照吗?

3. postgresql也是这样吗?或者说是在执行start transaction命令后就建立快照?谢啦

  • 写回答

2条回答 默认 最新

  • 幻灰龙 2021-02-17 00:13
    关注

    参考:

    这2篇解释的很清晰:

    https://www.cnblogs.com/sunjingwu/p/12386660.html

    https://www.cnblogs.com/digdeep/p/4947694.html

     

    MySQL/PG 都按这种方式自己动手验证应该是最好的路径。

     

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥20 删除和修改功能无法调用
  • ¥15 kafka topic 所有分副本数修改
  • ¥15 小程序中fit格式等运动数据文件怎样实现可视化?(包含心率信息))
  • ¥15 如何利用mmdetection3d中的get_flops.py文件计算fcos3d方法的flops?
  • ¥40 串口调试助手打开串口后,keil5的代码就停止了
  • ¥15 电脑最近经常蓝屏,求大家看看哪的问题
  • ¥60 高价有偿求java辅导。工程量较大,价格你定,联系确定辅导后将采纳你的答案。希望能给出完整详细代码,并能解释回答我关于代码的疑问疑问,代码要求如下,联系我会发文档
  • ¥50 C++五子棋AI程序编写
  • ¥30 求安卓设备利用一个typeC接口,同时实现向pc一边投屏一边上传数据的解决方案。
  • ¥15 SQL Server analysis services 服务安装失败