前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >由于查询语句中日期的格式引起的问题

由于查询语句中日期的格式引起的问题

作者头像
源哥
发布2018-08-28 11:06:54
8640
发布2018-08-28 11:06:54
举报
文章被收录于专栏:源哥的专栏

我这边有一个系统,在一个环境下运行完全正常,但迁到另外一个环境后,其中一个查询功能就莫名其妙的出现了问题,我通过检查,发现有一个很复杂的查询语句,在一个数据库环境下查询完全正常,在另外一个环境下查询就出问题了,报的错误是字符串的格式不对。

我首先就怀疑是数据库环境的问题,但检查发现,两边的数据库环境都是oracle817。其次我又怀疑是由于数据库中的数据引起的问题,后来检查发现数据没有问题。这样我就开始怀疑可能查询语句写法有问题了,但是为什么会在一个数据库环境可以,在另外一个数据库环境又不可以呢?这样我就开始对这个复杂的查询语句进行一句一句的检查,最后终于发现,语句是查询条件中日期的比较一边使用了日期格式,一边使用了字符串格式,下面给个简单的例子:

select * from tab a where a.testDate > ‘2005-11-27’;

上面语句中,我假定了表tab的testDate字段是Date格式,像上面这样已经语句,在有些环境下可能不会出错,有些环境就会出错了,因为在oracle中,数据库会将字段testDate的值自动先转换成字符串,然后再跟右边的字符串进行比较。只有转成成什么样格式的字符串,那就要根据安装数据库的环境里面的日期格式设置了,如果设置显示的日期格式位“YYYY-MM-DD”,那么就不会有问题,而设置成其它格式那么就出问题了。

正确的写法应该是将右边的字符串转换成日期格式,如下:

select * from tab a where a.testDate > TO_DATE(‘2005-11-27’,’YYYY-MM-DD’);

另外,尽量不要对左边的字段进行格式转换(比如说日期转换成字符串),因为这个的话,没一个查询的值都比较进行格式转换,这样比右边一个常量进行一次格式转换的效率低多了。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2005年11月27日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档