>데이터 베이스 >MySQL 튜토리얼 >내 Oracle 쿼리 결과가 ORA-00904: 잘못된 식별자인 이유는 무엇입니까?

내 Oracle 쿼리 결과가 ORA-00904: 잘못된 식별자인 이유는 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2025-01-17 08:42:09866검색

Why Does My Oracle Query Result in ORA-00904: Invalid Identifier?

ORA-00904: 구문 분석 중 잘못된 식별자 오류

문제 설명:

Oracle 데이터베이스에서 내부 조인 쿼리를 실행할 때 다음 오류가 발생합니다.

<code class="language-sql">ORA-00904: "TEAM"."DEPARTMENT_CODE": invalid identifier</code>

근본 원인:

오류의 근본 원인은 쿼리의 테이블 이름과 열 이름에 큰따옴표를 사용했기 때문입니다. Oracle 데이터베이스에서는 객체 이름이 모두 대문자이거나 따옴표 없이 작성되어야 합니다.

해결책:

이 문제를 해결하려면 쿼리의 테이블 및 열 이름에서 큰따옴표를 제거하고 DDL 스크립트에서 테이블을 생성할 때 큰따옴표를 사용하지 마세요.

올바른 SQL 쿼리는 다음과 같습니다.

<code class="language-sql">SELECT Employee.EMPLID as EmpID, 
       Employee.FIRST_NAME AS Name,
       Team.DEPARTMENT_CODE AS TeamID, 
       Team.Department_Name AS teamname
FROM PS_TBL_EMPLOYEE_DETAILS Employee
INNER JOIN PS_TBL_DEPARTMENT_DETAILS Team 
ON Team.DEPARTMENT_CODE = Employee.DEPTID</code>

DDL 스크립트에서는 큰따옴표를 사용하지 마세요.

가장 좋은 방법은 DDL 스크립트에 큰따옴표를 사용하지 않는 것입니다. 이름은 모두 대문자로 사용하는 것이 좋습니다:

<code class="language-sql">CREATE TABLE HRMS.PS_TBL_DEPARTMENT_DETAILS
(
  Company_Code VARCHAR2(255),
  Company_Name VARCHAR2(255),
  Sector_Code VARCHAR2(255),
  Sector_Name VARCHAR2(255),
  Business_Unit_Code VARCHAR2(255),
  Business_Unit_Name VARCHAR2(255),
  Department_Code VARCHAR2(255),
  Department_Name VARCHAR2(255),
  HR_ORG_ID VARCHAR2(255),
  HR_ORG_Name VARCHAR2(255),
  Cost_Center_Number VARCHAR2(255)
)</code>

이 접근 방식은 더 큰 유연성을 제공하고 일관되지 않은 대소문자로 인한 잠재적인 오류를 방지합니다. 예제 DDL의 중복 " " 열이 제거되었습니다.

위 내용은 내 Oracle 쿼리 결과가 ORA-00904: 잘못된 식별자인 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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