>데이터 베이스 >MySQL 튜토리얼 >Oracle SQL에서 날짜를 올바르게 비교하는 방법은 무엇입니까?

Oracle SQL에서 날짜를 올바르게 비교하는 방법은 무엇입니까?

DDD
DDD원래의
2025-01-17 10:36:14407검색

How to Correctly Compare Dates in Oracle SQL?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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