SanitySun 2015-02-27 13:54 采纳率: 100%
浏览 1715

关于oracle 同一行数据 两个时间段数据语句问题

各位好,目前对一个旧系统改造,从sql 改造为 orcle时,遇到了一个问题,原先的sql语句select Count(*) from yd where (BeginDate + BeginTime<=(('2015-01-28')+('10:00:00'))) and (EndDate + EndTime>(('2015-01-28')+('10:00:00'))) and (zyID='32') 时是可以查出来语句的,但是改为oracle时,语句如下
select Count(*) from yd where to_date(BeginDate || ' '|| BeginTime,'YYYY-MM-DD HH24:MI:SS') >=to_date('2015-01-28' || ' ' || '10:00:00','YYYY-MM-DD HH24:MI:SS') and to_date(EndDate || ' '|| EndTime,'YYYY-MM-DD HH24:MI:SS')< to_date('2015-01-28' || ' ' || '10:00:00','YYYY-MM-DD HH24:MI:SS') and (zyID='32')
却选不出来数据,请问是什么原因呢,!
表结构如下(https://img-ask.csdn.net/upload/201502/27/1425045166_710236.png)

  • 写回答

3条回答 默认 最新

  • save4me 2015-02-27 14:52
    关注

    参考How to concatenate time to a date
    你的BEGINDATE, ENDDATE, BEGINTIME, ENDTIME都是什么类型的?如果不是字符型的,试一下先用to_char把日期和时间字段转换成字符,然后使用||来链接字符
    另外你的zyID是字符类型还是整型的,如果是整型的,应该不需要引号。

    评论

报告相同问题?

悬赏问题

  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码