开发者社区 > 数据库 > 正文

当事务访问某行数据时,如何判断可见性?

已解决

当事务访问某行数据时,如何判断可见性?

展开
收起
云上静思 2022-09-19 14:58:06 361 0
1 条回答
写回答
取消 提交回答
  • 推荐回答

    当事务访问某行数据时,可按照以下步骤判断可见性:

    • 创建 ReadView(根据MVCC 隔离级别的不同,创建ReadView 的次数不同,详见下文)。

    • 若记录的 trx_id(即数据的版本号)< up_limit_id,说明在ReadView 产生前,此版本的生成事务已经提交,记录可见。

    • 若 trx_id > low_limit_id,说明ReadView 产生后,此版本的生成事务才产生,记录不可见。

    • 若 up_limit_id < trx_id < low_limit_id,若trx_id 在trx_ids 之中,生成事务仍活跃,记录不可见;若trx_id 不在trx_ids 中,生成事务已提交,记录可见。

    以上内容摘自《云原生数据库原理与实践》,这本书可以在电子工业出版社天猫店购买。

    2022-09-19 15:06:41
    赞同 展开评论 打赏
问答地址:

数据库领域前沿技术分享与交流

相关电子书

更多
事务、全局索引、透明分布式 立即下载
低代码开发师(初级)实战教程 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载