> 데이터 베이스 > MySQL 튜토리얼 > 내부 조인으로 Oracle 업데이트 쿼리를 올바르게 수행하는 방법은 무엇입니까?

내부 조인으로 Oracle 업데이트 쿼리를 올바르게 수행하는 방법은 무엇입니까?

Barbara Streisand
풀어 주다: 2025-01-25 04:47:14
원래의
178명이 탐색했습니다.

How to Correctly Perform an Oracle UPDATE Query with an INNER JOIN?

INNER JOIN을 사용하여 Oracle 데이터 업데이트

발생하는 "SQL 명령이 제대로 종료되지 않았습니다" 오류는 Oracle 구문 대신 MySQL 구문을 사용하기 때문에 발생합니다. 데이터 업데이트 및 INNER JOIN 사용에 대한 Oracle의 접근 방식은 약간 다릅니다.

이 오류를 해결하려면 다음과 같이 쿼리를 수정하면 됩니다.

<code class="language-sql">UPDATE table1
SET table1.value = (
  SELECT table2.CODE
  FROM table2
  WHERE table1.value = table2.DESC
)
WHERE table1.UPDATETYPE = 'blah'
AND EXISTS (
  SELECT table2.CODE
  FROM table2
  WHERE table1.value = table2.DESC
);</code>
로그인 후 복사

이 쿼리에서는 table1의 각 행에 대해 SET 절의 하위 쿼리가 실행되고 table2의 해당 행을 기준으로 값 값이 업데이트됩니다. WHERE 절은 일치하는 행만 업데이트되도록 합니다.

또는 인라인 보기의 업데이트 가능성에 따라 다음을 시도해 볼 수 있습니다.

<code class="language-sql">UPDATE
(
  SELECT table1.value AS OLD, table2.CODE AS NEW
  FROM table1
  INNER JOIN table2
  ON table1.value = table2.DESC
  WHERE table1.UPDATETYPE = 'blah'
) t
SET t.OLD = t.NEW;</code>
로그인 후 복사

이 방법은 인라인 뷰를 활용하여 조인을 수행한 다음 결과로 기본 테이블을 업데이트합니다.

위 내용은 내부 조인으로 Oracle 업데이트 쿼리를 올바르게 수행하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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