在Spring中集成Hibernate,实际上就是将Hibernate中用到的
数据源DataSource、 SessionFactory实例(通常使用Hibernate访问数据库时,应用程序会先创建SessionFactory实例)以及事务管理器都交由Spring容器管理。
整合时,可以只使用Spring配置文件(通常是applicationContext.xml文件,也可用其它命名)来完成两个框架初始化任务,不再使用hibernate.cfg.xml配置文件。
定义数据源DataSource
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"> <property name="driverClassName" value="com.mysql.jdbc.Driver"></property> <property name="url" value="jdbc:mysql://localhost:3306/yhssh?useUnicode=true&characterEncoding=UTF-8"> </property> <property name="username" value="root"></property> <property name="password" value=""></property> </bean>
通过声明的方式来管理SessionFactory实例
使用Spring的LocalSessionFactoryBean来配置Hibernate的SessionFactory,
通过Spring的IoC容器在配置 SessionFactory时为其注入数据源的引用。
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean"> <property name="dataSource" ref="dataSource"/> <property name="mappingDirectoryLocations"> <list> <value>classpath:com/yh/xml</value> </list> </property> <!-- Set some attributes about Hibernate --> <property name="hibernateProperties"> <props> <prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop> <!-- 设置Hibernate是否在控制台输出SQL语句,开发调试阶段通常设为true --> <prop key="hibernate.show_sql">false</prop> <!-- 设置Hibernate一个提交批次中的最大SQL语句数 --> <prop key="hibernate.jdbc.batch_size">50</prop> </props> </property> </bean>
在Spring配置文件中完成对SessionFactory的配置后,
便可以将SessionFactoryBean注入到其他Bean中,如注入DAO组件中。
当DAO组件获得SessionFactoryBean的引用后,就可以实现对数据库的访问。
定义Hibernate的事务管理器HibernateTransactionManager
<bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager"> <!-- 依赖注入上面定义的sessionFactory --> <property name="sessionFactory" ref="sessionFactory"/> </bean>
时间: 2024-11-08 18:39:26