总结项目中遇到的各种sql报错及Oracle问题。
1.ORA-01843: 无效的月份
报错信息如下:
org.springframework.dao.DataIntegrityViolationException:
### Error querying database. Cause: java.sql.SQLDataException: ORA-01843: 无效的月份
### The error may exist in file [D:\tomcat\tianheng\yshh-demo\WEB-INF\classes\mybatis\yshh\TrainersMapper.xml]
### The error may involve TrainersMapper.statisticsAgeCount-Inline
### The error occurred while setting parameters
### SQL: select EXTRACT(year FROM to_date(to_char(sysdate,'yyyy-mm-dd'),'yyyy-mm-dd'))-EXTRACT(year FROM to_date(tra.birthday,'yyyy-mm-dd')) as age, count(tra.TRAINERS_ID) as ageCount from tb_trainers tra where tra.birthday is not null AND tra.GONGDI_ID = ? group by tra.birthday order by age
### Cause: java.sql.SQLDataException: ORA-01843: 无效的月份
; SQL []; ORA-01843: 无效的月份
; nested exception is java.sql.SQLDataException: ORA-01843: 无效的月份
从中可以分析出是mapper文件中的sql出了问题,分析sql可知问题出在了生日这一块,数据库的生日存储格式是yyyy-mm-dd,字段类型为varchar。从提示可以看出应该是某个出生日期的月份不合法(非01-12),于是只能慢慢从数据库排查是哪个人的出生日期出了问题,如果以前没有出现这种情况,那说明是最近添加的数据导致的,可按插入时间(创建时间)排序查找,效率快得多。
问题原因:某人出生日期不合法(eg1996-63-15)
处理结果:将数据修正。