
首先我们来看一下Hibernate进行 *** 作的步骤。比如添加用户的一个步骤。在上一篇博客中《八步详解Hibernate的搭建及使用》详细介绍到了Hibernate使用的步骤。以下的代码来自上篇博客,在此为了解释提出的问题,只做一个截图,若想看完整代码示例,可以参考《八步详解Hibernate的搭建及使用》
看截图,可以看出,Hibernate *** 作的步骤如下:
1 获得Configuration对象
2 创建SessionFactory
3 创建Session
4 打开事务
5 进行持久化 *** 作。比如上面的添加用户 *** 作
6 提交事务
7 发生异常,回滚事务
8 关闭事务
使用Hibernate进行访问持久层,每次都要进行这八个步骤。但是若使用Spring对Hibernate进行管理,又是怎么样的呢?
首先,Spring对Hibernate提供了HibernateTemple类。这个模版类对session进行封装。并且Spring会默认为自动提交事务。所在在dao层直接写入thissave(Object)即可。
在实践中,遇到了一个问题,无法插入数据库,经过一番折腾,多次实验,验证,总结一下原因,结果如下:
注意:所有的 *** 作都必须在事务中进行。若单纯的使用Hibernate,则事务需要手动开启提交关闭 *** 作。当然也可以在Hibernate配置文件中,自动提交。
若使用Spring管理Hibernate,则默认的是自动提交事务。但是在此,需要注意的是:若使用Spring在配置文件中配置数据源而不使用hibernatecfgxml,则可以成功插入数据库,因为HibernateTemple默认提供自动提交事务。在Spring的配置文件配置数据源如下:使用此数据源需要的jar如下:commons-dbcpjar,commons-pooljar,msbasejar,mssqlserverjar, msutiljar,sqljdbc4jar;
[html] view plaincopyprint
<bean id="dataSource" class="orgapachecommonsdbcpBasicDataSource">
<property name="driverClassName" value="commicrosoftjdbcsqlserverSQLServerDriver"></property>
<property name="url" value="jdbc:sqlserver://19216824176:1433;database=test"></property>
<property name="username" value="sa"></property>
<property name="password" value="123"></property>
</bean>
<bean id="sessionFactory" class="orgspringframeworkormhibernate3LocalSessionFactoryBean">
<property name="dataSource" ref="dataSource"></property>
<!-- hibernate属性配置 -->
<property name="hibernateProperties">
<props>
<prop key="hibernatedialect">orghibernatedialectSQLServerDialect</prop>
<prop key="hibernatehbm2ddlauto">update</prop>
</props>
</property>
lt;!-- 如果采用传统的hbmxml的方式,可以采用如下方式来简化注册hbmxml的步骤,并且class为LocalSessionFactoryBean -->
<property name="mappingLocations">
<list>
<value>classpath:Userhbmxml</value>
</list>
</property>
</bean>
若Spring中不是直接配置数据源,而是使用hibernatecfgxml,则是无法若直接thissave(Object),则无法插入数据库中,但是可以保存中缓存中。因为所有的 *** 作都是在事务中执行的,而hibernatecfgxml数据源则默认是不是自动提交的。解决的办法如下:可以在hibernatecfgxml中填写:
<property name="hibernateconnectionautocommit">true</property>
以下Spring使用hibernatecfgxml数据源
[html] view plaincopyprint
<bean id="sessionFactory" class="orgspringframeworkormhibernate3LocalSessionFactoryBean">
<property name="configLocation">
<value>classpath:hibernatecfgxml</value>
</property>
<property name="mappingLocations">
<list>
<value>classpath:Userhbmxml</value>
</list>
</property>
</bean>
以上,介绍了Spring来管理Hibernate的好处在于,不用手动创建SessionFactory,Session,不用手动开启提交关闭事务,这一切完全都是由Spring来管理。并且Spring还提供了HibernateTemple的工具,使一切 *** 作简单方便。
dao层在Spring配置文件中配置如下:
[html] view plaincopyprint
<<span style="font-size:12px;">bean id="userDao" class="comUserDaoUserDaoImpl">
<property name="sessionFactory" ref="sessionFactory"></property>
</bean></span>
则在dao层的代码如下:
[html] view plaincopyprint
package comUserDao;
import orgspringframeworkormhibernate3HibernateTemplate;
import comuserUser;
public class UserDaoImpl extends HibernateTemplate implements UserDao {
@Override
public void insert(User user) {
thissave(user);
}
}
这只是其中的关键的代码,至于完整的小demo,已经上传。
正如上述所说,一切 *** 作尽在事务中,事务这个概念想必大家不陌生吧,一般情况,事务应该在业务逻辑层,而不是在dao层应用。并且Spring对事务有很好的封装,自己有一套事务管理的封装,使业务逻辑与事务管理分离,进一步达到解耦作用。下一篇博客,我们继续会讲解Spring管理Hibernate中的事务管理。
<property name="connectionautocommit">true</property>
在Hibernate配置文件中,增加这句就可以了、好像说是Hibernate缓存的问题。浪费了我一天的时间。
JDBC既不是spring的东西,也不是hibernate的,它只是J2EE的一种规范。
hibernate作为持久层框架,它解决的是Java对象持久化的问题,但从本质上说还是必须通过jdbc api来完成 *** 作数据库的工作。
spring的核心实际上只有2个东西,IoC和AOP,与数据库没有什么关系。它的扩展包中提供了对各种持久层框架的集成,包括hibernate。当然还有一个简单的jdbcTemplate。
至于hibernate和jdbc的选取,取决于你自身的业务以及数据量。
以上就是关于spring怎么管理hibernate全部的内容,包括:spring怎么管理hibernate、SSH中我用增删改(使用spring生成的hibernate模版),sql语句已发出,数据库没更新,、一般用hibernate来处理数据库,而不是用spring的JDBC来处理数据库等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)