PostgreSQL中Tuple可见性判断的基本逻辑是什么

网友投稿 409 2024-02-25

***中Tuple可见性判断的基本逻辑是什么

这篇文章主要介绍“***中Tuple可见性判断的基本逻辑是什么”,在日常操作中,相信很多人在***中Tuple可见性判断的基本逻辑是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”***中Tuple可见性判断的基本逻辑是什么”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

***中Tuple可见性判断的基本逻辑是什么

判断逻辑

((Xmin == my-transaction &&       inserted by the current transaction

Cmin < my-command &&          before this command, and

 (Xmax is null ||            the row has not been deleted, or

(Xmax == my-transaction &&      it was deleted by the current transaction

Cmax >= my-command)))       but not before this command,

||                     or

(Xmin is committed &&          the row was inserted by a committed transaction, and

  (Xmax is null ||            the row has not been deleted, or

(Xmax == my-transaction &&     the row is being deleted by this transaction

Cmax >= my-command) ||      but it’s not deleted “yet”, or

    (Xmax != my-transaction &&    the row was deleted by another transaction

Xmax is not committed))))    that has not been committed

其中,my-command在PG中通过cmin/cmax体现.

cmin/cmax

如下例所示,游标在删除命令前定义,因此Tuple可见.10:51:21 (xdb@[local]:5432)testdb=# DELETE FROM mvcc_demo; DELETE 3 10:51:22 (xdb@[local]:5432)testdb=#  10:51:22 (xdb@[local]:5432)testdb=# BEGIN WORK; BEGIN 10:51:22 (xdb@[local]:5432)testdb=#* INSERT INTO mvcc_demo VALUES (1); INSERT 0 1 10:51:22 (xdb@[local]:5432)testdb=#* INSERT INTO mvcc_demo VALUES (2); INSERT 0 1 10:51:22 (xdb@[local]:5432)testdb=#* INSERT INTO mvcc_demo VALUES (3); INSERT 0 1 10:51:22 (xdb@[local]:5432)testdb=#* SELECT xmin, cmin, xmax, cmax, * FROM mvcc_demo;  xmin | cmin | xmax | cmax | val  ------+------+------+------+-----  2400 |    0 |    0 |    0 |   1  2400 |    1 |    0 |    1 |   2  2400 |    2 |    0 |    2 |   3 (3 rows) 10:51:23 (xdb@[local]:5432)testdb=#* DECLARE c_mvcc_demo CURSOR FOR [local] xdb@testdb-# SELECT xmin, cmin, xmax, cmax, * FROM mvcc_demo; --> 定义游标 DECLARE CURSOR 10:51:34 (xdb@[local]:5432)testdb=#* DELETE FROM mvcc_demo; --> 删除数据 DELETE 3 10:51:34 (xdb@[local]:5432)testdb=#* SELECT xmin, cmin, xmax, cmax, * FROM mvcc_demo;  xmin | cmin | xmax | cmax | val  ------+------+------+------+----- (0 rows) 10:51:35 (xdb@[local]:5432)testdb=#* FETCH ALL FROM c_mvcc_demo; --> 游标在删除命令前定义,因此可见  xmin | cmin | xmax | cmax | val  ------+------+------+------+-----  2400 |    0 | 2400 |    0 |   1  2400 |    1 | 2400 |    1 |   2  2400 |    2 | 2400 |    2 |   3 (3 rows)

到此,关于“***中Tuple可见性判断的基本逻辑是什么”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:TiDB 7.1.0 LTS特性解读资源管控应该知道的6件事
下一篇:TiDB 7.1.0资源管控特性试用心得
相关文章