> 데이터 베이스 > MySQL 튜토리얼 > ORA-00936을 피하기 위해 Oracle 11g에서 INSERT SELECT를 올바르게 사용하는 방법은 무엇입니까?

ORA-00936을 피하기 위해 Oracle 11g에서 INSERT SELECT를 올바르게 사용하는 방법은 무엇입니까?

DDD
풀어 주다: 2024-12-23 20:12:10
원래의
954명이 탐색했습니다.

How to Correctly Use INSERT SELECT in Oracle 11g to Avoid ORA-00936?

Oracle 11G에서 SELECT 쿼리를 통해 데이터 삽입

Oracle 11G에서 INSERT SELECT 문을 사용하면 하위 쿼리를 사용하여 한 테이블에서 다른 테이블로 효율적인 데이터 전송이 가능합니다. 그러나 구문이 올바르지 않으면 사용자에게 예기치 않은 오류가 발생할 수 있습니다.

사용자 쿼리:

사용자가 다음을 사용하여 하위 쿼리의 결과를 새 테이블에 삽입하려고 했습니다. 다음 진술:

insert into table1 (col1, col2) values (select t1.col1, t2.col2 from oldtable1 t1, oldtable2 t2);
로그인 후 복사

그러나 사용자는 다음과 같은 상황을 겪었습니다. 오류:

SQL Error: ORA-00936: missing expression
로그인 후 복사

해결책:

제공된 구문이 잘못되었습니다. Oracle의 INSERT SELECT 문에는 다른 SQL 언어에서 일반적으로 사용되는 VALUES 키워드가 필요하지 않습니다. 올바른 구문은 다음과 같습니다.

insert into table1 (col1, col2)
select t1.col1, t2.col2
from oldtable1 t1, oldtable2 t2
로그인 후 복사

즉, 명령문 시작 부분에서 VALUES 키워드를 제거하면 됩니다. 이를 통해 Oracle은 INSERT SELECT 쿼리를 올바르게 실행하고 하위 쿼리 결과를 table1에 삽입할 수 있습니다.

위 내용은 ORA-00936을 피하기 위해 Oracle 11g에서 INSERT SELECT를 올바르게 사용하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿