집 >데이터 베이스 >MySQL 튜토리얼 >내 Oracle 쿼리 결과가 ORA-00904: 잘못된 식별자인 이유는 무엇입니까?
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!