목차
Insert in oracle lock the table?
데이터 베이스 Oracle Oracle에 삽입하면 테이블이 잠길까요?

Oracle에 삽입하면 테이블이 잠길까요?

May 30, 2022 pm 04:29 PM
oracle

Oracle의 Insert는 테이블을 잠급니다. Oracle이 insert와 같은 DML 문을 실행할 때 두 개의 insert 문이 동시에 테이블에 대해 작업을 시도하면 세션이 종료됩니다. 다른 세션이 커밋되거나 롤백되어 교착 상태가 발생합니다.

Oracle에 삽입하면 테이블이 잠길까요?

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

Insert in oracle lock the table?

Oracle lock the table

ORACLE이 insert 등의 DML 문을 실행할 때 먼저 자동으로 해당 테이블에 TM 잠금을 적용합니다. TM 잠금을 획득한 후 자동으로 TX 유형 잠금을 신청합니다. 두 개 이상의 세션이 테이블의 동일한 레코드에 대해 DML 언어를 실행하는 경우 첫 번째 세션은 해당 레코드를 잠그고, 다른 세션은 첫 번째 세션이 커밋된 후 TX 잠금이 해제될 때까지 대기 상태가 되며, 나머지 세션만 잠글 수 있습니다.

두 개의 insert 문이 동일한 PK 또는 고유 값을 가진 데이터를 동시에 테이블에 삽입하려고 시도하여 세션이 차단되고 다른 세션이 커밋 또는 롤백되기를 기다리므로 교착 상태가 발생하기 때문입니다.

이 경우 세션 중 하나가 제출되면 다른 하나는 ORA-00001을 보고합니다. 고유 제약 조건이 위반되어 교착 상태가 종료되거나 세션 중 하나가 롤백되고 다른 하나는 정상적으로 실행될 수 있습니다. .

오라클에서 테이블을 잠그는 이유는 프로그램이 테이블에 삽입을 수행하고 아직 커밋되지 않은 경우 다른 프로그램도 동일한 테이블에 삽입을 수행하면 리소스 사용 예외가 발생하기 때문입니다. , 테이블 잠금.

테이블을 잠그는 주요 이유는 다음과 같습니다.

(1) 프로그램 A는 tableA의 삽입을 실행하고 커밋 전에 프로그램 B도 tableA를 삽입합니다. 이때 리소스 사용 중 예외가 발생합니다. . Table

(2) 테이블 잠금은 병렬이 아닌 동시성으로 발생하는 경우가 많습니다(병렬에서는 한 스레드가 데이터베이스를 작동하면 다른 스레드는 데이터베이스, CPU 및 I/O 할당 원칙을 작동할 수 없음)

확률을 줄이는 방법 of table locking :

(1) insert, update, delete 문 실행과 커밋 사이의 시간을 줄입니다. 구체적으로 일괄 실행을 단일 실행으로 변경하여 SQL 자체의 비실행 속도를 최적화합니다

(2) 트랜잭션이 비정상적으로 롤백되는 경우

테이블을 잠그는 이유는 행 데이터가 수정되어 행 데이터를 제출하는 것을 잊었으며 이로 인해 테이블도 잠기게 됩니다.

지식 확장:

결정을 내리기 전에 이유를 확인하는 것이 좋습니다.

1 테이블 잠금 쿼리의 코드 형식은 다음과 같습니다.

select count(*) from v$locked_object;
select * from v$locked_object;
로그인 후 복사

2. 어떤 테이블이 잠겨 있는지 확인하세요.

select b.owner,b.object_name,a.session_id,a.locked_mode from v$locked_object a,dba_objects b where b.object_id = a.object_id;
로그인 후 복사

3 어떤 세션이 잠겼는지 확인하세요.

select b.username,b.sid,b.serial#,logon_time from v$locked_object a,v$session b where a.session_id = b.sid order by b.logon_time;
로그인 후 복사

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

위 내용은 Oracle에 삽입하면 테이블이 잠길까요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. 크로스 플레이가 있습니까?
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Oracle의 테이블 스페이스 크기를 확인하는 방법 Oracle의 테이블 스페이스 크기를 확인하는 방법 Apr 11, 2025 pm 08:15 PM

Oracle 테이블 스페이스 크기를 쿼리하려면 다음 단계를 따르십시오. 쿼리를 실행하여 테이블 스페이스 이름을 결정하십시오. 쿼리를 실행하여 테이블 스페이스 크기를 쿼리하십시오. sum (bytes)을 total_size, sum (bytes_free)으로 sum (bytes_free), sum (bytes) - sum (bytes_free)으로 dba_data_fices where tablespace_.

오라클에서 시간을 얻는 방법 오라클에서 시간을 얻는 방법 Apr 11, 2025 pm 08:09 PM

Oracle에는 시간을 얻는 방법이 있습니다. current_timestamp : 현재 시스템 시간을 반환합니다. Systimestamp : current_timestamp보다 나노 초보다 더 정확합니다. sysdate : 시간 부분을 제외하고 현재 시스템 날짜를 반환합니다. to_char (sysdate, 'yyy-mm-dd hh24 : mi : ss') : 현재 시스템 날짜와 시간을 특정 형식으로 변환합니다. 추출 : 1 년, 월 또는 시간과 같은 시간 값에서 특정 부분을 추출합니다.

Oracle의 인스턴스 이름을 보는 방법 Oracle의 인스턴스 이름을 보는 방법 Apr 11, 2025 pm 08:18 PM

Oracle에서 인스턴스 이름을 보는 세 가지 방법이 있습니다. 명령 줄에 명령. "show instance_name"을 사용하십시오. sql*plus의 명령. 운영 체제의 작업 관리자, Oracle Enterprise Manager 또는 운영 체제를 통해 환경 변수 (Linux의 Oracle_Sid)를 확인하십시오.

Oracle View를 암호화하는 방법 Oracle View를 암호화하는 방법 Apr 11, 2025 pm 08:30 PM

Oracle View 암호화를 사용하면보기에서 데이터를 암호화 할 수 있으므로 민감한 정보의 보안을 향상시킬 수 있습니다. 단계에는 다음이 포함됩니다. 1) 마스터 암호화 키 생성 (MEK); 2) 암호화 된 뷰 생성, 암호화 할보기 및 MEK를 지정하는 것; 3) 사용자가 암호화 된보기에 액세스하도록 승인합니다. 암호화 된 뷰 작동 방식 : 사용자가 암호화 된보기를 쿼리 할 때 Oracle은 MEK를 사용하여 데이터를 해독하여 공인 사용자 만 읽기 쉬운 데이터에 액세스 할 수 있도록합니다.

Oracle 설치를 제거하는 방법에 실패했습니다 Oracle 설치를 제거하는 방법에 실패했습니다 Apr 11, 2025 pm 08:24 PM

Oracle 설치 실패에 대한 방법 제거 : Oracle Service를 닫고 Oracle Program 파일 및 레지스트리 키 삭제, Oracle 환경 변수를 제거하고 컴퓨터를 다시 시작하십시오. 제거되지 않으면 Oracle 범용 제거 도구를 사용하여 수동으로 제거 할 수 있습니다.

유효하지 않은 수의 Oracle을 확인하는 방법 유효하지 않은 수의 Oracle을 확인하는 방법 Apr 11, 2025 pm 08:27 PM

Oracle 유효하지 않은 숫자 오류는 데이터 유형 불일치, 숫자 오버플로, 데이터 변환 오류 또는 데이터 손상으로 인해 발생할 수 있습니다. 문제 해결 단계에는 데이터 유형 확인, 디지털 오버 플로우 감지, 데이터 변환 확인, 데이터 손상 확인 및 NLS_NUMERIC_CHARACTERS 매개 변수 구성 및 데이터 확인 로깅 활성화와 같은 다른 가능한 솔루션 탐색이 포함됩니다.

Oracle Cursor를 닫는 문제를 해결하는 방법 Oracle Cursor를 닫는 문제를 해결하는 방법 Apr 11, 2025 pm 10:18 PM

Oracle Cursor Closure 문제를 해결하는 방법에는 다음이 포함됩니다. Close 문을 사용하여 커서를 명시 적으로 닫습니다. For Update 절에서 커서를 선언하여 범위가 종료 된 후 자동으로 닫히십시오. 연관된 PL/SQL 변수가 닫히면 자동으로 닫히도록 사용 절에서 커서를 선언하십시오. 예외 처리를 사용하여 예외 상황에서 커서가 닫혀 있는지 확인하십시오. 연결 풀을 사용하여 커서를 자동으로 닫습니다. 자동 제출을 비활성화하고 커서 닫기를 지연시킵니다.

Oracle 사용자를 설정하는 방법 Oracle 사용자를 설정하는 방법 Apr 11, 2025 pm 08:21 PM

Oracle에서 사용자를 만들려면 다음 단계를 따르십시오. 사용자 명령문을 사용하여 새 사용자를 만듭니다. 보조금 명세서를 사용하여 필요한 권한을 부여하십시오. 선택 사항 : 리소스 문을 사용하여 할당량을 설정하십시오. 기본 역할 및 임시 테이블 스페이스와 같은 다른 옵션을 구성하십시오.

See all articles