广告
返回顶部
首页 > 资讯 > 数据库 >PostgreSQL中Tuple可见性判断分析
  • 800
分享到

PostgreSQL中Tuple可见性判断分析

2024-04-02 19:04:59 800人浏览 独家记忆
摘要

本篇内容主要讲解“postgresql中Tuple可见性判断分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Postgresql中Tuple可见性判断分析”吧

本篇内容主要讲解“postgresql中Tuple可见性判断分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Postgresql中Tuple可见性判断分析”吧!

一、xmin/xmax是当前事务

Tuple.xmin或xmax是当前事务的情况,事务状态为IN_PROGRESS,其判断逻辑如下:
插入未提交
If xmin == 当前事务 Then
  If xmax == 当前事务 Then
   元组不可见
  Else
   元组可见
  End If
End If

如下例所示:

15:40:39 (xdb@[local]:5432)testdb=# 
15:40:40 (xdb@[local]:5432)testdb=# begin;
BEGIN
15:40:44 (xdb@[local]:5432)testdb=#* insert into t_session1 values(1);
INSERT 0 1
15:40:52 (xdb@[local]:5432)testdb=#* update t_session1 set id = 0;
UPDATE 1
15:41:02 (xdb@[local]:5432)testdb=#* select lp,lp_off,t_xmin,t_xmax from heap_page_items(get_raw_page('t_session1',0));
 lp | lp_off | t_xmin | t_xmax 
----+--------+--------+--------
  1 |   8160 |   2370 |   2370    --> 2370插入数据,2370更新数据,该Tuple不可见
  2 |   8128 |   2370 |      0    --> 2370更新后的数据,该Tuple可见
(2 rows)

插入已提交
If xmax == 当前事务 Then
  元组不可见
End If

15:41:11 (xdb@[local]:5432)testdb=#* delete from t_session1;
DELETE 1
15:41:36 (xdb@[local]:5432)testdb=#* select lp,lp_off,t_xmin,t_xmax from heap_page_items(get_raw_page('t_session1',0));
 lp | lp_off | t_xmin | t_xmax 
----+--------+--------+--------
  1 |   8160 |   2370 |   2370    --> 2370更新该Tuple,不可见
  2 |   8128 |   2370 |   2370    --> 2370删除该Tuple,不可见
(2 rows)
15:41:38 (xdb@[local]:5432)testdb=#* commit;
COMMIT

注意:在这种情况下(xmax == 当前事务),xmin状态不可能是ABORTED,因为不可能Update/Delete不存在的元组(事务未提交可视为不存在).

二、xmin&xmax非当前事务

xmin和xmax均不是当前事务,假定快照为ST1:ST2:XIP[],其判断逻辑如下:
If xmin.STATUS == COMMITTED Then
  If xmax < ST1 && xmax.STATUS == COMMITTED Then
    元组不可见
  If xmax ∉ XIP[] && xmax.STATUS == COMMITTED Then
    元组不可见
  Else
    元组可见
  End If
Else
  元组不可见
End If

到此,相信大家对“PostgreSQL中Tuple可见性判断分析”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

您可能感兴趣的文档:

--结束END--

本文标题: PostgreSQL中Tuple可见性判断分析

本文链接: https://www.lsjlt.com/news/64275.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • PostgreSQL中Tuple可见性判断分析
    本篇内容主要讲解“PostgreSQL中Tuple可见性判断分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“PostgreSQL中Tuple可见性判断分析”吧...
    99+
    2022-10-18
  • PostgreSQL 源码解读(118)- MVCC#3(Tuple可见性判断)
    本节介绍了PostgreSQL判...
    99+
    2022-10-18
  • PostgreSQL中Tuple可见性判断的基本逻辑是什么
    这篇文章主要介绍“PostgreSQL中Tuple可见性判断的基本逻辑是什么”,在日常操作中,相信很多人在PostgreSQL中Tuple可见性判断的基本逻辑是什么问题上存在疑惑,小编查阅了各式资料,整理出...
    99+
    2022-10-19
  • Python判断值是否在list或set中的性能对比分析
    本文实例对比分析了Python判断值是否在list或set中的执行性能。分享给大家供大家参考,具体如下: 判断值是否在set集合中的速度明显要比list快的多, 因为查找set用到了hash,时间在O(1)...
    99+
    2022-06-04
    性能 Python list
  • .Net中字符串不变性与相等判断的特殊应用场景分析
    这篇文章主要介绍了.Net中字符串不变性与相等判断的特殊应用场景分析的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇.Net中字符串不变性与相等判断的特殊应用场景分析文章都会有所收获,下面我们一起来看看吧。问题请...
    99+
    2023-06-30
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作