Spring MVC Hibernate 中的一个疑问
最近开发项目遇到一个问题。
错误日志跟踪发现是spring IOC报出来的错误
org.springframework.beans.factory.BeanCreationException: Error creating bean with name ****: Injection of autowired dependencies failed;nested exception is ......nested exception is org.hibernate.MappingException: Could not get constructor for org.hibernate.persister.entity.SingleTableEntityPersister
竟然是hibernate的注入问题,由于代码并没有添加新的实体,也找到任何有注释问题的service,dao,entitiy类。无奈下只能通过svn对比代码差异。
结果发现由于开发需求某开发新人在某个表映射实体中添加了一个方法public double getAvg(),其方法内容就是针对此实体的某些。由于本人并没有参考过hibernate orm的最新源码,对其原理仅仅停留于曾经远古年代的XML经验--没有在XML中配置的hibernate不会对其进行映射。推论到目前的注解,没有注解的应当也不会被映射。
由于没有找到其他原因,也只能对此方法下手,从代码中注释了此方法和相关代码,发现程序正常跑了,catch!!!
-----------------------------------------------至此罪魁祸首代码已经找到---------------------------------------------------- 既然找到问题代码,hibernate的原因也基本被排除,那么出错的责任应在spring IOC。将该方法名改为avg() 发现程序可以正常运行,方法名由get变为set,程序也可正常运行,删除该改方法添加属性avg发现程序同样正常,最后保留get情况下添加了set方法,程序依然正常。
这让我对之前的spring认识有了变更,入门时师傅告诉我spring是根据属性去查找get/set方法进行注入。从上面的表现上来看其顺序应该是获取所有的get方法,查找对应的set方法,不存在就报错。注入原理与属性无关!
------------------------------------------------------------总结-------------------------------------------------------------------
经此一役,让我收获最大的是对于项目管理上要严格把控代码质量,对所有源码在经过多层测试和审核。在技术上加强新人培训,杜绝简单问题的出现。同时也不应迷信于前人的经验和方法,做到谨慎质疑,大胆证实。最后本人从事的是业务架构设计对于技术了解一般,如有技术错误请指出。
上一篇: 转:Java对象持久化技术概述
下一篇: Hibernate与mybitas的比较
推荐阅读
-
Spring MVC+FastJson+hibernate-validator整合的完整实例教程
-
Spring Security在标准登录表单中添加一个额外的字段
-
spring.net中的IoC、DI和MVC
-
Spring.Net是怎么在MVC中实现注入的(原理)
-
asp.net mvc 简单项目框架的搭建(二)—— Spring.Net在Mvc中的简单应用
-
Mysql在Spring中配置hibernate的字符编码格式
-
Spring MVC中异常处理的三种方式
-
Spring MVC + JPA开发中遇到对象延迟加载,session关闭的情况解决方法 JPAMVCSpringBeanHibernate
-
spring mvc3中的addFlashAttribute方法
-
spring mvc3中的addFlashAttribute方法