RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1598235
Accepted
CyberNinja
CyberNinja
Asked:2024-10-30 04:07:23 +0000 UTC2024-10-30 04:07:23 +0000 UTC 2024-10-30 04:07:23 +0000 UTC

xmax 字段值

  • 772

假设有两个事务:T1 和 T2。

BEGIN; -- Т1

UPDATE table
SET amount = 1
WHERE id = 1;

SELECT xmin, xmax FROM table
WHERE id = 1; 
-- получаем: xmin = xid транзакции Т1, xmax = 0

让我们开始第二笔交易:

BEGIN; -- T2

UPDATE table
SET amount = 2
WHERE id = 1; 
-- ожидание завершения транзакции Т1 

我们完成第一笔交易:

COMMIT;

我们继续第二个:

SELECT xmin, xmax FROM table
WHERE id = 1; 
-- получаем: xmin и xmax равный идентификатору (xid) транзакции Т2.

问题:为什么事务 T1 在更新后开始看到 xmax = 0,而事务 T2 在更新后开始看到 xmax = xid(T2)?我想强调的是,这些值相对于更新数据的事务是可见的。

PS 我之前不知何故没有注意到这一点,并且总是认为如果事务更改了一行,那么相对于其自身,它会在新行中看到 xmax = 0,因为这是一个新元组,而且还没有人更改它。

postgresql
  • 1 1 个回答
  • 38 Views

1 个回答

  • Voted
  1. Best Answer
    Мелкий
    2024-10-30T14:59:45Z2024-10-30T14:59:45Z

    xmin和xmax很好地解释了 MVCC 是如何实现的,但在实际代码中一切都更加复杂。Pageinspect将有助于澄清在这种情况下发生的情况,借助它我们将研究信息掩码:

    melkij=> create table "table" (id int, amount int);
    CREATE TABLE
    
    melkij=> insert into "table" values (1,2);
    INSERT 0 1
    
    melkij=# SELECT t_ctid, t_xmin, t_xmax, raw_flags, combined_flags
             FROM heap_page_items(get_raw_page('table', 0)),
               LATERAL heap_tuple_infomask_flags(t_infomask, t_infomask2)
             WHERE t_infomask IS NOT NULL OR t_infomask2 IS NOT NULL;
     t_ctid | t_xmin | t_xmax |      raw_flags      | combined_flags 
    --------+--------+--------+---------------------+----------------
     (0,1)  |    864 |      0 | {HEAP_XMAX_INVALID} | {}
    

    在这里,新插入的行将具有执行插入的事务的 xmin,但 xmax 不会。

    # T1
    melkij=> begin;
    BEGIN
    melkij=*> UPDATE "table"
    SET amount = 1
    WHERE id = 1;
    UPDATE 1
    
    # T2
    melkij=> begin;
    BEGIN
    melkij=*> UPDATE "table"
    SET amount = 2
    WHERE id = 1;
    
     t_ctid | t_xmin | t_xmax |                    raw_flags                     | combined_flags 
    --------+--------+--------+--------------------------------------------------+----------------
     (0,2)  |    864 |    865 | {HEAP_XMIN_COMMITTED,HEAP_HOT_UPDATED}           | {}
     (0,2)  |    865 |      0 | {HEAP_XMAX_INVALID,HEAP_UPDATED,HEAP_ONLY_TUPLE} | {}
    
    # T1 commit
    
     t_ctid | t_xmin | t_xmax |                                raw_flags                                 | combined_flags 
    --------+--------+--------+--------------------------------------------------------------------------+----------------
     (0,2)  |    864 |    865 | {HEAP_XMIN_COMMITTED,HEAP_HOT_UPDATED}                                   | {}
     (0,3)  |    865 |    866 | {HEAP_XMIN_COMMITTED,HEAP_UPDATED,HEAP_HOT_UPDATED,HEAP_ONLY_TUPLE}      | {}
     (0,3)  |    866 |    866 | {HEAP_XMAX_KEYSHR_LOCK,HEAP_XMAX_LOCK_ONLY,HEAP_UPDATED,HEAP_ONLY_TUPLE} | {}
    

    现在该行的第三个版本出现了 (xmin=xmax=866),从名称为 的标志中可以明显看出为什么这样的 xmax HEAP_XMAX_LOCK_ONLY。通过这种方式,我们留下信息,以便下一个想要更新该行的事务必须检查是否仍然有一个事务正在运行,其 XID 等于 xmax 中写入的值。在行锁定的实现中,xmax 与其他信息掩码标志积极结合使用。

    • 3

相关问题

  • 表不可见

  • 如何修复 postgresql 堆栈深度限制超出错误?

  • 如何为 PostgreSQL 添加 ENUM

  • PostgreSQL:如何在冲突中执行插入操作?

  • 在哪里可以看到所有 postgre 宏?

  • SQL。将SELECT结果合并为一行,需要将得到的结果替换为可读的结果

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5