>데이터 베이스 >MySQL 튜토리얼 >MySQL의 INSERT INTO...SELECT를 사용할 때 모든 열을 효율적으로 보존하는 방법은 무엇입니까?

MySQL의 INSERT INTO...SELECT를 사용할 때 모든 열을 효율적으로 보존하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-12-04 13:10:10476검색

How to Efficiently Preserve All Columns When Using MySQL's INSERT INTO...SELECT?

효율적인 INSERT INTO...SELECT를 사용하여 열 데이터 보존

모든 열을 유지하면서 한 MySQL 테이블에서 다른 MySQL 테이블로 데이터를 전송할 때, 공통 과제가 발생합니다. INSERT INTO this_table_archive (*) VALUES (SELECT * FROM this_table WHERE Entry_date < '2011-01-01 00:00:00') 형식 사용; 원하는 결과를 얻지 못할 수도 있습니다.

MySQL 매뉴얼에 설명된 올바른 구문은 다음과 같습니다.

INSERT INTO this_table_archive (col1, col2, ..., coln) 
SELECT col1, col2, ..., coln
FROM this_table
WHERE entry_date < '2011-01-01 00:00:00'; 

이 수정된 형식은 대상 테이블의 각 열 이름을 명시적으로 지정하여

게다가 id 열이 자동 증가로 구성되어 있고 두 테이블 모두 데이터가 포함되어 있는 경우에는 제외하는 것이 유리할 수 있습니다. 열 목록. 이렇게 하면 중복 ID 삽입으로 인해 발생할 수 있는 충돌을 방지할 수 있습니다. 그러나 대상 테이블이 비어 있는 경우에는 이 생략이 필요하지 않습니다.

위 내용은 MySQL의 INSERT INTO...SELECT를 사용할 때 모든 열을 효율적으로 보존하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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