Oracle SQL 日期比较及员工入职日期计数
问题:
我需要统计1994年6月20日之后入职的员工数量,但遇到了错误:
<code class="language-sql">Select employee_id, count(*) From Employee Where to_char(employee_date_hired, 'DD-MON-YY') > '31-DEC-95'; </code>
错误:
"JUN' invalid identifier."
解答:
字符串与日期比较:
错误的原因在于将字符串 ('31-DEC-95') 与日期值 (employee_date_hired) 进行比较。要进行日期比较,需要使用 TO_DATE() 函数将字符串转换为日期,或者使用日期字面量。
1. TO_DATE() 函数:
<code class="language-sql">select employee_id from employee where employee_date_hired > to_date('31-DEC-95','DD-MON-YY')</code>
2. 日期字面量:
如果希望在不同区域设置下保持一致的行为并进行精确的日期比较,可以使用日期字面量。
<code class="language-sql">select employee_id from employee where employee_date_hired > date '1995-12-31'</code>
技巧:
<code class="language-sql">select employee_id, count(*) from employee where employee_date_hired > date '1995-12-31' group by employee_id</code>
以上是如何正确比较 Oracle SQL 中的日期以统计特定日期之后雇用的员工?的详细内容。更多信息请关注PHP中文网其他相关文章!