>데이터 베이스 >MySQL 튜토리얼 >Oracle 데이터베이스 관리에서 글로벌 임시 테이블과 개인 임시 테이블은 어떻게 다릅니까?

Oracle 데이터베이스 관리에서 글로벌 임시 테이블과 개인 임시 테이블은 어떻게 다릅니까?

Linda Hamilton
Linda Hamilton원래의
2025-01-16 20:06:11633검색

How Do Global and Private Temporary Tables Differ in Oracle Database Management?

Oracle 임시 테이블: 임시 데이터 스토리지 자세히 살펴보기

관계형 데이터베이스 관리 분야에서 임시 테이블을 생성하는 것은 다양한 데이터 처리 시나리오에서 일반적인 요구 사항입니다. Microsoft SQL Server에서 DECLARE 문을 사용하여 임시 테이블을 생성하는 구문은 비교적 간단합니다. 그러나 Oracle 데이터베이스에서는 접근 방식이 다르므로 추가 탐색이 필요합니다.

Oracle은 전역 임시 테이블과 개인 임시 테이블이라는 두 가지 유형의 임시 테이블을 제공합니다. 전역 임시 테이블은 생성 문에서 GLOBAL TEMP 키워드로 표시되며 여러 사용자 세션에서 표시되고 액세스 가능합니다. 반면, Oracle 18c에 도입된 프라이빗 임시 테이블은 생성 세션 전용으로 성능 최적화를 위해 자주 사용됩니다.

전역 임시 테이블 생성

Oracle에서 전역 임시 테이블을 생성하려면 다음 구문을 사용하세요.

<code class="language-sql">CREATE GLOBAL TEMPORARY TABLE 表名 (列定义)
ON COMMIT [DELETE ROWS | PRESERVE ROWS]</code>

기본적으로 전역 임시 테이블의 데이터는 트랜잭션이 커밋되면 삭제됩니다. 그러나 ON COMMIT 절을 사용하면 원하는 동작을 지정할 수 있습니다.

  • 행 삭제: 제출 시 데이터를 삭제합니다.
  • 행 보존: 제출 후에도 데이터가 유지되므로 다른 세션에서 액세스할 수 있습니다.

다음 예를 고려해 보세요.

<code class="language-sql">CREATE GLOBAL TEMPORARY TABLE sales_temp (
  order_id NUMBER,
  quantity NUMBER
)
ON COMMIT PRESERVE ROWS;</code>

비공개 임시 테이블 만들기

Oracle 18c 이상에서 사용할 수 있는 개인 임시 테이블은 생성 세션 내에서 메모리에 데이터를 저장하여 향상된 성능을 제공합니다. 다음 구문을 사용하여 생성됩니다.

<code class="language-sql">CREATE PRIVATE TEMPORARY TABLE 表名 (列定义)</code>

예는 다음과 같습니다.

<code class="language-sql">CREATE PRIVATE TEMPORARY TABLE order_temp AS
  SELECT order_id, product_id, quantity
  FROM orders
  WHERE order_date = '2023-08-22';</code>

참고 및 대안

특정 상황에서는 임시 테이블이 유용할 수 있지만 주의해서 사용해야 합니다. 임시 테이블을 자주 생성하고 삭제하면 데이터베이스에 성능 오버헤드가 발생할 수 있습니다.

임시 테이블의 대안은 하나의 SQL 문에서 임시 결과 집합을 생성할 수 있는 인라인 뷰(CTE)를 사용하는 것입니다. 이 접근 방식은 잠재적으로 성능을 향상시키고 별도의 임시 테이블 생성 필요성을 줄일 수 있습니다.

위 내용은 Oracle 데이터베이스 관리에서 글로벌 임시 테이블과 개인 임시 테이블은 어떻게 다릅니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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