Oracle - 从日期字符串转换时选择两个日期(含)之间的记录

标签 oracle

我有以下 Oracle 查询

SELECT *
FROM table 
WHERE date_opened 
BETWEEN ((TO_DATE('2011-08-01', 'yyyy-mm-dd') - to_date('01-JAN-1970','DD-MON-YYYY')) * (86400)) 
AND ((TO_DATE('2011-08-31', 'yyyy-mm-dd') - to_date('01-JAN-1970','DD-MON-YYYY')) * (86400))

这几乎可以工作,但它不包括日期为 2011-08-31 的日期记录。有任何想法吗?这可能与我转换日期字符串的方式有关...

UPDATE:我真的应该说日期实际上是一个 UNIX 时间戳。这就是我使用 86400 和 01-JAN-1970 的原因

谢谢你:)

最佳答案

如果区间的上限未包含在您的结果中,那么您可能正在构建一个关于上限的“独占”过滤器。因此,只需将一天添加到上限即可。即

AND ((TO_DATE(...) - to_date(...) + 1) * (86400)) - 1

在 Oracle 中,+1 用于日期时间算术时会增加一天。

注意:正如 Ollie 所说,BETWEEN .. AND 创建了一个包容性过滤器,但您的算术可能会通过将事物转换为秒来改变该行为

关于Oracle - 从日期字符串转换时选择两个日期(含)之间的记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7385217/

相关文章:

sql - 数据库:流水线函数

sql - Oracle 内联生成数字列(单条语句)

python oracle SQL查询转换

oracle - 检查数据库中是否存在表 - PL SQL

java - 如何通过java代码执行Oracle sql脚本

sql - Oracle,创建按范围分区的索引

Oracle 无法将数据插入 varchar2(4000 char) 列

sql - 甲骨文 SQL : How to show empty weeks/weeks without data?

linux - 将 bash 用户输入传递给 sql 语句时出错

sql - 如何优化在 UPDATE 中追加到 CLOB 的性能?