oarcle执行报错提示:SQL 错误 [1839] [22008]: ORA-01839: 指定月份的日期无效问题解决

分享个有趣的sql错误排查解决。昨天晚上有厂家反应说我们有个视图查询数据的时候查不完整,有报错,联系我们排查处理。

拿到视图后我自己先试着跑了下,看到后也是纳闷儿

以下是我的处理思路:

既然是提示日期无效 ,那就从日期相关的字段下手,查看视图创建语句逐个注释执行,定位问题字段

定位到的问题字段

sql 复制代码
to_char(to_date(m.for_execute_time,'mm-dd hh24:mi'),'hh24:mi') as OEOREExecStTime, --要求执行时间

稍微解释下:这个写法时就是将01-01 08:00转为08:00

那为什么会有这个报错,我也头一回见,既然如此就是用笨办法逐条数据分析

跑到以下时间数据时就可以确定了,闰年的数据格式判断。

sql 复制代码
SELECT to_char(to_date(m.for_execute_time, 'MM-DD HH24:MI'), 'HH24:MI') as OEOREExecStTime,
 m.for_execute_time, m.*
FROM inpord.order_execute m
JOIN adt.inpatient n ON m.ipid = n.ipid
WHERE m.is_execute <> 'D'
AND n.ipid = '11588150'
and execute_time >='20240201000000'
and execute_time <='20240301000000'

因为m.for_execute_time没有年份,系统无法判断是否闰年,则报了这个错误,那就要改写下这个sql了,挑个带日期的,跟这个字段拼接下,再进行转换

sql 复制代码
--原sql
to_char(to_date(m.for_execute_time, 'MM-DD HH24:MI'), 'HH24:MI') as OEOREExecStTime
--现sql
to_char(to_date(SUBSTR(m.for_execute_date_time, 1, 8) || ' ' ||SUBSTR(m.for_execute_time, 7, 5), 'YYYYMMDD HH24:MI'), 'HH24:MI') AS OEOREExecStTime

完结撒花🌸

相关推荐
alonewolf_9910 分钟前
Redis Stack全面解析:从JSON存储到布隆过滤器,打造高性能Redis扩展生态
数据库·redis·json
正在走向自律8 小时前
金仓数据库KingbaseES中级语法详解与实践指南
数据库·oracle·kingbasees·金仓数据库·信创改造
Gofarlic_oms18 小时前
Windchill用户登录与模块访问失败问题排查与许可证诊断
大数据·运维·网络·数据库·人工智能
我是小疯子669 小时前
Python变量赋值陷阱:浅拷贝VS深拷贝
java·服务器·数据库
Zoey的笔记本9 小时前
2026告别僵化工作流:支持自定义字段的看板工具选型与部署指南
大数据·前端·数据库
静听山水9 小时前
docker安装starrocks
数据库
学编程的小程10 小时前
从“兼容”到“超越”:金仓KESBSON引擎如何借多模融合改写文档数据库规则
数据库
千层冷面10 小时前
数据库分库分表
java·数据库·mysql·oracle
DBA小马哥11 小时前
金仓数据库引领国产化替代新范式:构建高效、安全的文档型数据库迁移解决方案
数据库·安全·mongodb·dba·迁移学习
企业对冲系统官11 小时前
基差风险管理系统日志分析功能的架构与实现
大数据·网络·数据库·算法·github·动态规划