목차
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 도구

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

MySQL을 제거하고 잔류 파일을 청소하는 방법 MySQL을 제거하고 잔류 파일을 청소하는 방법 Apr 29, 2025 pm 04:03 PM

MySQL을 안전하고 철저하게 제거하고 모든 잔차 파일을 정리하려면 다음 단계를 따르십시오. 1. MySQL 서비스 중지; 2. MySQL 패키지 제거; 3. 구성 파일 및 데이터 디렉토리를 정리하십시오. 4. 제거가 철저한 지 확인하십시오.

비즈니스 세계에서 오라클의 역할 비즈니스 세계에서 오라클의 역할 Apr 23, 2025 am 12:01 AM

Oracle은 데이터베이스 회사 일뿐 만 아니라 클라우드 컴퓨팅 및 ERP 시스템의 리더이기도합니다. 1. Oracle은 데이터베이스에서 클라우드 서비스 및 ERP 시스템에 이르기까지 포괄적 인 솔루션을 제공합니다. 2. OracleCloud는 AWS와 Azure에 도전하여 IAA, PAAS 및 SAAS 서비스를 제공합니다. 3. E-BusinessSuite 및 FusionApplications와 같은 Oracle의 ERP 시스템은 기업이 운영을 최적화하는 데 도움이됩니다.

Mongodb vs. Oracle : 주요 차이점 이해 Mongodb vs. Oracle : 주요 차이점 이해 Apr 16, 2025 am 12:01 AM

MongoDB는 대규모 비정형 데이터를 처리하는 데 적합하며 Oracle은 거래 일관성이 필요한 엔터프라이즈 수준의 응용 프로그램에 적합합니다. 1. MongoDB는 사용자 행동 데이터 처리에 적합한 유연성과 고성능을 제공합니다. 2. Oracle은 안정성과 강력한 기능으로 유명하며 금융 시스템에 적합합니다. 3. MongoDB는 문서 모델을 사용하고 Oracle은 관계형 모델을 사용합니다. 4. MongoDB는 소셜 미디어 응용 프로그램에 적합하지만 Oracle은 엔터프라이즈 수준의 응용 프로그램에 적합합니다.

Mongodb vs. Oracle : 필요에 맞는 올바른 데이터베이스 선택 Mongodb vs. Oracle : 필요에 맞는 올바른 데이터베이스 선택 Apr 22, 2025 am 12:10 AM

MongoDB는 구조화되지 않은 데이터 및 높은 확장 성 요구 사항에 적합한 반면 Oracle은 엄격한 데이터 일관성이 필요한 시나리오에 적합합니다. 1. MongoDB는 소셜 미디어 및 사물 인터넷에 적합한 다양한 구조물에 데이터를 유연하게 저장합니다. 2. Oracle 구조화 된 데이터 모델은 데이터 무결성을 보장하고 금융 거래에 적합합니다. 3. MongoDB는 파편을 통해 수평으로 비늘을, RAC를 통해 수직으로 오라클 스케일링됩니다. 4. MongoDB는 유지 보수 비용이 낮지 만 Oracle은 유지 보수 비용이 높지만 완전히 지원됩니다.

유지 보수를 중단 한 후 Centos의 선택 유지 보수를 중단 한 후 Centos의 선택 Apr 14, 2025 pm 08:51 PM

Centos는 중단되었으며 대안은 다음과 같습니다. 1. Rocky Linux (Best Compatibility); 2. Almalinux (Centos와 호환); 3. Ubuntu 서버 (구성 필수); 4. Red Hat Enterprise Linux (상업용 버전, 유료 라이센스); 5. Oracle Linux (Centos 및 Rhel과 호환). 마이그레이션시 고려 사항은 호환성, 가용성, 지원, 비용 및 커뮤니티 지원입니다.

vscode가 Kotlin을 실행할 수 있습니다 vscode가 Kotlin을 실행할 수 있습니다 Apr 15, 2025 pm 06:57 PM

VS 코드에서 Kotlin을 실행하는 다음 환경 구성이 필요합니다. Java Development Kit (JDK) 및 Kotlin Compiler Kotlin 관련 플러그인 (예 : Kotlin Langu

YI 프레임 워크에 어떤 소프트웨어가 더 좋습니까? YI 프레임 워크에 권장되는 소프트웨어 YI 프레임 워크에 어떤 소프트웨어가 더 좋습니까? YI 프레임 워크에 권장되는 소프트웨어 Apr 18, 2025 pm 11:03 PM

기사의 첫 번째 단락의 초록 : Yi 프레임 워크 응용 프로그램을 개발하기위한 소프트웨어를 선택할 때 여러 가지 요소를 고려해야합니다. Xcode 및 Android Studio와 같은 기본 모바일 애플리케이션 개발 도구는 강력한 제어 및 유연성을 제공 할 수 있지만 React Native 및 Flut 모바일 개발에 새로운 개발자의 경우 AppSheet 및 Glide와 같은 저 코드 또는 노 코드 플랫폼이 응용 프로그램을 빠르고 쉽게 구축 할 수 있습니다. 또한 AWS Amplify 및 Firebase와 같은 클라우드 서비스 제공 업체는 포괄적 인 도구를 제공합니다.

MySQL vs. Oracle : 라이센스, 기능 및 혜택 MySQL vs. Oracle : 라이센스, 기능 및 혜택 May 08, 2025 am 12:05 AM

MySQL과 Oracle의 주요 차이점은 라이센스, 기능 및 장점입니다. 1. 라이센스 : MySQL은 무료 사용을위한 GPL 라이센스를 제공하고 Oracle은 독점 라이센스를 채택합니다. 2. 기능 : MySQL에는 간단한 기능이 있으며 웹 응용 프로그램 및 중소 기업에 적합합니다. Oracle은 강력한 기능을 가지고 있으며 대규모 데이터 및 복잡한 비즈니스에 적합합니다. 3. 장점 : MySQL은 오픈 소스 무료이며 스타트 업에 적합하며 Oracle은 성능이 신뢰할 수 있으며 대기업에 적합합니다.

See all articles