sql 取自然年的方法

    

  select nvl(sum(order_ticket_num),0)
          from crs_order c
          left join crs_order_contact cc
            on c.id_order = cc.id_order
         where cc.openid = #{openid,jdbcType=VARCHAR}
           and c.tm_update >
               to_date((to_char(trunc(sysdate, 'year') - 1, 'yyyy') ||
                       '-12-31 23:59:59'),
                       'yyyy-mm-dd hh24:mi:ss')
           and c.tm_update <= sysdate
           and c.is_del = 0
           and c.order_status != 10021030
           and c.order_status != 10021040
           and cc.is_del = 0
           and c.product_type='10271010'
           and c.source_code = #{sourceCode,jdbcType=VARCHAR}    

 

用的oracle数据库,以当前系统时间为参数,取表里时间字段大于上一年12月31日23:59:59秒并且小于当前系统时间的值 就是自然年内的数据。  如果测试不通过,则麻烦校对一下 线上库之间的系统时间 是否一致

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值