Oracle where 时间条件带有空格或.0解决

前提条件:作为条件的date字段存在oracle 表里类型为Date,现需把该字段作为其它表查询条件入参。

 -- create_time 为Date类型 last_time 为Date类型
select * from test_temp where create_time >  last_time; -- 抛异常

 
select * from test_temp where create_time > to_date(last_time,'yyyy-mm-dd hh24:mi:ss'); -- 抛异常日期后有个.0  例:2022-09-15 19:30:20.0

select * from test_temp where create_time > to_char(last_time,'yyyy-mm-dd hh24:mi:ss');-- 抛异常Date直传日期中间带空格例:2022 - 09 - 15 19 : 30 : 20 

-- 先在service层把 last_time用SimpleDateFormat ft = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss"); String lastTime = ft.format(last_time); 使用作为入参传给SQL,该SQL正常执行
select * from test_temp where create_time > to_char(lastTime ,'yyyy-mm-dd hh24:mi:ss');

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值