MySQL과 달리 Oracle 데이터베이스에는 테이블 작업을 위한 직접적인 IF EXISTS
구문이 없습니다. 그러나 다음 방법을 통해 비슷한 기능을 얻을 수 있습니다.
가장 효율적인 방법은 "테이블이 존재하지 않습니다" 예외를 포착하는 것입니다.
<code class="language-sql">BEGIN EXECUTE IMMEDIATE 'DROP TABLE ' || table_name; EXCEPTION WHEN OTHERS THEN IF SQLCODE != -942 THEN RAISE; END IF; END;</code>
이 방법을 사용하면 다른 방법처럼 테이블이 두 번 존재하는지 확인할 필요가 없습니다.
IF EXISTS
구문(Oracle 23c 이상) Oracle 버전 23c부터 모든 DROP
DDL 작업은 더 간단한 IF EXISTS
구문을 지원합니다.
<code class="language-sql">BEGIN EXECUTE IMMEDIATE 'DROP TABLE IF EXISTS ' || table_name; END;</code>
다른 Oracle 객체 유형에도 유사한 예외 처리 블록을 사용할 수 있습니다.
<code class="language-sql">BEGIN EXECUTE IMMEDIATE 'DROP SEQUENCE ' || sequence_name; EXCEPTION WHEN OTHERS THEN IF SQLCODE != -2289 THEN RAISE; END IF; END;</code>
<code class="language-sql">BEGIN EXECUTE IMMEDIATE 'DROP VIEW ' || view_name; EXCEPTION WHEN OTHERS THEN IF SQLCODE != -942 THEN RAISE; END IF; END;</code>
<code class="language-sql">BEGIN EXECUTE IMMEDIATE 'DROP TRIGGER ' || trigger_name; EXCEPTION WHEN OTHERS THEN IF SQLCODE != -4080 THEN RAISE; END IF; END;</code>
<code class="language-sql">BEGIN EXECUTE IMMEDIATE 'DROP INDEX ' || index_name; EXCEPTION WHEN OTHERS THEN IF SQLCODE != -1418 THEN RAISE; END IF; END;</code>
<code class="language-sql">BEGIN EXECUTE IMMEDIATE 'ALTER TABLE ' || table_name || ' DROP COLUMN ' || column_name; EXCEPTION WHEN OTHERS THEN IF SQLCODE != -904 AND SQLCODE != -942 THEN RAISE; END IF; END;</code>
위 내용은 Oracle에서 테이블 존재 여부를 확인하고 조건부 DDL 작업을 수행하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!