Oracle 11G에서 INSERT SELECT 문과 관련된 "ORA-00936" 오류 문제 해결
"ORA-00936: 표현식 누락" 오류 Oracle 11G에서 INSERT SELECT 문을 실행할 때 발생할 수 있습니다. 이 문제를 해결하기 위해 구체적인 사례를 분석해 보겠습니다.
문제:
SQL 문이 하위 쿼리의 데이터를 테이블에 삽입하려고 합니다.
insert into table1 (col1, col2) values (select t1.col1, t2.col2 from oldtable1 t1, oldtable2 t2);
하위 쿼리를 별도로 실행하면 올바르게 작동하여 oldtable1과 oldtable2라는 두 테이블에서 행을 검색합니다. 그러나 INSERT 문에 대한 데이터 소스로 실행하면 "ORA-00936: 누락된 표현식" 오류가 발생합니다.
해결책:
오류의 원인은 다음과 같습니다. INSERT 문의 구문이 잘못되었습니다. SELECT 문을 활용하여 대상 테이블을 채울 때는 VALUES 키워드가 필요하지 않습니다. 올바른 구문은 다음과 같습니다.
insert into table1 (col1, col2) select t1.col1, t2.col2 from oldtable1 t1, oldtable2 t2
VALUES 부분을 생략하면 INSERT 문이 하위 쿼리를 올바르게 실행하고 table1을 선택한 데이터로 채웁니다.
위 내용은 Oracle 11g INSERT SELECT 문에서 'ORA-00936: 표현식 누락'을 해결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!