Oracle SQL의 날짜 비교
Oracle SQL에서 날짜를 비교할 때 날짜 형식이 올바른지 확인하는 것이 중요합니다. 기본적으로 Oracle은 날짜를 숫자로 해석하므로 제대로 처리하지 않으면 오류가 발생할 수 있습니다.
일반적인 문제는 문자열을 사용하여 날짜를 나타내는 것입니다. 문자열(예: '31-DEC-95')은 유효한 날짜로 인식되지 않으며 "잘못된 식별자" 오류를 발생시킵니다. 이 문제를 해결하려면 날짜 리터럴이나 TO_DATE() 함수를 사용하여 문자열을 날짜로 변환하십시오.
TO_DATE() 사용
TO_DATE() 함수를 사용하면 날짜 문자열의 형식을 지정하고 이를 날짜 데이터 유형으로 변환할 수 있습니다. 예:
<code class="language-sql">select employee_id from employee where employee_date_hired > to_date('31-12-1995','DD-MM-YYYY')</code>
이 쿼리는 '31-12-1995' 문자열을 'DD-MM-YYYY' 형식을 사용하는 날짜로 변환하고 이를 Employee_date_hired 열과 비교합니다.
날짜 텍스트 사용
날짜 리터럴은 Oracle SQL에서 날짜를 지정하는 또 다른 방법입니다. 'YYYY-MM-DD' 형식으로 작성되며 시간 요소를 포함하지 않습니다. 예:
<code class="language-sql">select employee_id from employee where employee_date_hired > date '1995-12-31'</code>
이 쿼리는 Employee_date_hired 열을 날짜 리터럴 '1995-12-31'(1995년 12월 31일을 나타냄)과 비교합니다.
처리 시간 및 지역
Oracle 날짜에는 시간 구성 요소가 포함되어 있으므로 정확한 비교가 필요한 경우 시간 요소를 고려해야 합니다. 또한 날짜 형식은 NLS_DATE_FORMAT 및 NLS_DATE_LANGUAGE 설정에 따라 달라질 수 있습니다. 로케일 전체에서 일관된 날짜 처리를 보장해야 하는 경우 YYYY-MM-DD 형식을 사용하고 NLS_DATE_FORMAT 및 NLS_DATE_LANGUAGE를 그에 따라 설정하세요.
직원별 집계
특정 날짜 이후에 채용된 직원 수를 계산하고 결과를 직원 ID별로 그룹화하려면 다음 쿼리를 사용할 수 있습니다.
<code class="language-sql">select employee_id, count(*) from employee where employee_date_hired > date '1995-12-31' group by employee_id</code>
이 쿼리는 1995년 12월 31일 이후에 고용된 직원 수를 직원 ID별로 그룹화하여 제공합니다.
위 내용은 Oracle SQL에서 날짜를 올바르게 비교하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!