分享个有趣的sql错误排查解决。昨天晚上有厂家反应说我们有个视图查询数据的时候查不完整,有报错,联系我们排查处理。
拿到视图后我自己先试着跑了下,看到后也是纳闷儿
以下是我的处理思路:
既然是提示日期无效,那就从日期相关的字段下手,查看视图创建语句,逐个注释,执行,定位问题字段
定位到的问题字段
to_char(to_date(m.for_execute_time,'mm-dd hh24:mi'),'hh24:mi') as OEOREExecStTime, --要求执行时间
稍微解释下:这个写法时就是将01-01 08:00转为08:00
那为什么会有这个报错,我也头一回见,既然如此就是用笨办法逐条数据分析
跑到以下时间数据时就可以确定了,闰年的数据格式判断。
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
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
完结撒花🌸