Informix SQL 比较 Where 语句上的 DateTime 值

Posted

技术标签:

【中文标题】Informix SQL 比较 Where 语句上的 DateTime 值【英文标题】:Informix SQL Compare DateTime value on Where Statement 【发布时间】:2014-01-07 09:22:05 【问题描述】:

我有一个名为entrytimestamp 的日期时间字段,该字段的内容例如:2014-01-07 16:20:00。我想查询09:00:00点之后所有有entrytimestamp的数据,不管是什么日期。

我有一个原型查询:

select *
from trading
where to_char(entrytimestamp, "%H%M%S") >= "090000"

但我认为这在逻辑上是错误的,因为它会比较文本字符串,而不是序列值。正确的做法是什么?

【问题讨论】:

【参考方案1】:

使用EXTEND()函数提取时间部分:

select *
from mytable
where extend(entrytimestamp, hour to second) > '09:00:00'

【讨论】:

是否保证使用时间顺序而不是字母顺序进行比较? 没有区别:当时间在字段中使用前导零格式化时,时间和字母排序是相同的【参考方案2】:

不知道效果好不好 但您可以直接与日期时间的时间部分进行比较,

我认为这里的演员应该表现得很快(只是切断了日期)

select *

from (select getdate() as mydatetime) as data

where cast(mydatetime as time) > cast('09:00:00' as time)

编辑,刚刚注意到这是针对 Informix SQL 的,所以不确定它是否有效,抱歉

【讨论】:

以上是关于Informix SQL 比较 Where 语句上的 DateTime 值的主要内容,如果未能解决你的问题,请参考以下文章

SQL语句where多条件查询怎么写

MS SQL Server 中的链接 Informix 表忽略标准?

Informix 11.5 SQL 语句性能监控方法及实现

SQL语句—where条件查询

Informix SQL — CASE 语句中的错误

informix 中update 前2条记录的 SQL语句