springmvc框架的项目,如何在controller中使用dao访问数据库

如题所述



springmvc框架中,controller和其他的bean是被分别扫描的,原因是如果不这样配置,controller就会被扫描两次,从而导致事物等问题。

通常情况下,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访问数据库
标签:

温馨提示:答案为网友推荐,仅供参考
相似回答
大家正在搜