时间:2021-07-01 10:21:17 帮助过:3人阅读
通常情况下,controller是不允许直接使用dao的,一个合理的设计就是在sevice中去调用dao。
但是如果有临时的需求需要在controller中访问数据库,那怎么办呢?
有两种方法。
方法1:在web.xml中配置,使spring对事物的控制设计请求的整个生命周期。
<!--配置Spring的OpenSessionInViewFilter,以解决懒加载异常的问题 -->
<filter>
<filter-name>OpenSessionInViewFilter</filter-name>
<filter-class>org.springframework.orm.hibernate4.support.OpenSessionInViewFilter</filter-class>
<init-param>
<!--指定sessionfactory的名字,默认为sessionFactory -->
<param-name>sessionFactoryBeanName</param-name>
<param-value>sessionFactory</param-value>
</init-param>
</filter>
这也能解决在jsp页面中你去对象.对象.对象时,告诉你session已关闭的问题。
方法2:
直接使用sessionfactory。对数据库的访问都是通过sessionfactory执行的,所以可以在controller中直接注入sessionfactory对象,访问数据库时opensession即可。
网上都没有简单快捷的解决方案,特记录在此。
springmvc框架的项目,如何在controller中使用dao访问数据库
标签: