如何查看任意 Oracle 会话正在使用的事务隔离级别

发布于 2024-09-18 03:21:11 字数 66 浏览 7 评论 0原文

我试图找出特定会话(不是我自己的会话)在 Oracle 服务器上的隔离级别。有 av$.. view 可以得到这个吗?

I am trying to find out what isolation level a particular session (not my own) has on an oracle server. Is there a v$.. view to get this?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

初熏 2024-09-25 03:21:11

您可以测试 v$transactionflag 列中的第 28 位[1]

SELECT s.sid, s.serial#,
  CASE BITAND(t.flag, POWER(2, 28))
    WHEN 0 THEN 'READ COMMITTED'
    ELSE 'SERIALIZABLE'
  END AS isolation_level
FROM v$transaction t, v$session s
WHERE t.addr = s.taddr
  AND s.sid = :sid
  AND s.serial# = :serial;

请记住,v$transaction 仅列出活动事务[2];例如,您需要发出插入/更新/删除/合并,或使用“for update”[3]

You can test bit 28 in the flag column in v$transaction[1].

SELECT s.sid, s.serial#,
  CASE BITAND(t.flag, POWER(2, 28))
    WHEN 0 THEN 'READ COMMITTED'
    ELSE 'SERIALIZABLE'
  END AS isolation_level
FROM v$transaction t, v$session s
WHERE t.addr = s.taddr
  AND s.sid = :sid
  AND s.serial# = :serial;

Just remember that v$transaction only lists active transactions[2]; for example, you need to issue an insert/update/delete/merge, or use "for update"[3].

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文