Oracle数据库问题及解决方案记录

总结项目中遇到的各种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)

处理结果:将数据修正。

你可能感兴趣的:(Oracle,SQL)