sql – 使用BETWEEN或<=,> =表示Oracle时间戳

我的Oracle表有一个列tmstp,其中包含TIMESTAMP(3)WITH TIME ZONE数据类型.

当我运行以下查询

SELECT COUNT(column1) 
  FROM table1 
 WHERE tmstp BETWEEN to_timestamp_tz('10-OCT-10 05.00.00.000000000 AM -05:00','DD-MON-RR HH.MI.SSXFF AM TZR')
                 AND to_timestamp_tz('11-OCT-10 04.59.59.999999999 AM -05:00','DD-MON-RR HH.MI.SSXFF AM TZR');

它提供的计数大约是以下查询的两倍:

SELECT COUNT(column1) 
  FROM table1 
 WHERE tmstp >= to_timestamp_tz('10-OCT-10 05.00.00.000000000 AM -05:00','DD-MON-RR HH.MI.SSXFF AM TZR') 
   AND tmstp <= to_timestamp_tz('11-OCT-10 04.59.59.999999999 AM  -05:00','DD-MON-RR HH.MI.SSXFF AM TZR');

我认为他们应该给出相同的结果.关于可能发生的事情的任何输入?我该怎么调试呢?

解决方法

抱歉,添麻烦了.我想到了.我的问题实际上也存在缺陷,因为我编辑它来隐藏机密数据.

在其中一个查询中,AM和时区偏移之间存在额外的空白,从而导致不同的结果.

愚蠢的我.

因此,如果转换的时间戳字符串与空格有点关闭,则答案可能会关闭.

相关文章

SELECT a.*,b.dp_name,c.pa_name,fm_name=(CASE WHEN a.fm_n...
if not exists(select name from syscolumns where name=&am...
select a.*,pano=a.pa_no,b.pa_name,f.dp_name,e.fw_state_n...
要在 SQL Server 2019 中设置定时自动重启,可以使用 Window...
您收到的错误消息表明数据库 &#39;EastRiver&#39; 的...
首先我需要查询出需要使用SQL Server Profiler跟踪的数据库标...