>데이터 베이스 >Oracle >Oracle 격리 수준을 쿼리하는 방법

Oracle 격리 수준을 쿼리하는 방법

WBOY
WBOY원래의
2022-06-13 10:58:337427검색

oracle에서 격리 수준을 쿼리하는 방법: 1. "declare trans_id...begin trans_id :=...;end;" 문을 사용하여 현재 세션을 트랜잭션에 넣습니다. 2. "SELECT s.sid"를 사용합니다. , s. serial#,CASE...WHEN 0 THEN '....'ELSE '...' END AS..." 문은 격리 수준을 쿼리할 수 있습니다.

Oracle 격리 수준을 쿼리하는 방법

이 튜토리얼의 운영 환경: Windows 10 시스템, Oracle 버전 12c, Dell G3 컴퓨터.

Oracle의 격리 수준을 쿼리하는 방법

Oracle 트랜잭션의 격리 수준을 확인하는 방법

Oracle은 더 번거롭습니다. 다음 명령문을 실행하세요

1): 현재 세션을 트랜잭션에 두세요

declare
trans_id Varchar2(100);
begin
trans_id := dbms_transaction.local_transaction_id( TRUE );
end;

2): 격리 수준 쿼리

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
JOIN v$session s ON t.addr = s.taddr AND s.sid = sys_context('USERENV', 'SID');

Oracle 격리 수준을 쿼리하는 방법

참고:

1): v$transaction이 존재하지 않는 경우 먼저 사용자 권한이 충분한지 여부를 고려하세요.

2): 빈 오류가 보고되는 경우; 두 번째 문장을 실행하면 트랜잭션이 아직 생성되지 않았기 때문입니다(따라서 첫 번째 문장을 먼저 실행한 다음 두 번째 문장을 실행하세요).

추천 튜토리얼: "Oracle Video Tutorial"

위 내용은 Oracle 격리 수준을 쿼리하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.