>데이터 베이스 >MySQL 튜토리얼 >데이터를 필터링하기 위해 SQL에서 임시 테이블을 효율적으로 생성하려면 어떻게 해야 합니까?

데이터를 필터링하기 위해 SQL에서 임시 테이블을 효율적으로 생성하려면 어떻게 해야 합니까?

DDD
DDD원래의
2025-01-03 06:12:39380검색

How Can I Efficiently Create a Temporary Table in SQL to Filter Data?

CREATE TABLE AS를 사용하여 SQL에서 임시 테이블 생성

임시 테이블을 생성하여 특정 기준에 따라 데이터를 선택하려는 경우 제공된 쿼리의 Register_type과 같이 올바른 구문을 사용하려면 CREATE TABLE을 사용해야 합니다. AS문. 귀하의 경우 수정된 쿼리는 다음과 같습니다.

CREATE TEMP TABLE temp1 AS
SELECT
    egauge.dataid,
    egauge.register_type,
    egauge.timestamp_localtime,
    egauge.read_value_avg
FROM
    rawdata.egauge
WHERE
    register_type LIKE '%gen%'
ORDER BY
    dataid, timestamp_localtime;

설명:

CREATE TABLE 문과 달리 CREATE TABLE AS는 두 가지를 모두 수행합니다. 테이블 생성과 데이터 삽입이 동시에 가능합니다. 이를 통해 생성 당시 데이터의 스냅샷인 임시 테이블을 생성할 수 있습니다. 이 임시 테이블은 현재 세션 내에서만 표시되며 세션이 종료되면 자동으로 사라집니다.

CREATE TABLE AS의 장점:

  • 효율성: SELECT INTO와 같은 다른 방법을 사용하는 것보다 임시 테이블을 생성하는 더 빠르고 효율적인 방법입니다.
  • 이식성: 이는 SQL 표준의 일부이며 다양한 데이터베이스 시스템에서 작동합니다.
  • 유연성: 테이블 생성 중 데이터 필터링 및 정렬이 가능합니다.

대체 구문을 사용하는 경우 사용됨:

  • 만들기 VIEW: 기본 테이블의 실시간 변경 사항을 반영하는 동적 결과 집합을 원하는 경우.
  • SELECT INTO: 이는 일반적으로 임시 테이블을 생성하는 데 권장되지 않습니다. 그러나 빠른 일회성 데이터 집계에 사용할 수 있습니다.
  • CREATE TABLE LIKE: 이 구문은 데이터를 복사하지 않고 기존 테이블과 동일한 구조의 테이블만 생성합니다.

위 내용은 데이터를 필터링하기 위해 SQL에서 임시 테이블을 효율적으로 생성하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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