在DAO中如何获得session对象

来源:互联网 发布:网络机顶盒电视猫 编辑:程序博客网 时间:2024/05/16 17:22

最近一直在学习spring整合Hibernate的知识,通过学习了解了大概的流程,纯属个人的理解,如有错误还请指明!!

首先是在application.xml文件中配置数据源和sessionFactory:

<!-- 配置c3p0 数据库连接池 -->
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"
destroy-method="close">
<property name="driverClass" value="com.mysql.jdbc.Driver" />
<property name="jdbcUrl"
value="jdbc:mysql://localhost:3306/fashion?useUnicode=true&amp;characterEncoding=utf-8" />
<property name="user" value="root" />
<property name="password" value="admin" />
<property name="maxIdleTime" value="20" />
<property name="maxPoolSize" value="200" />
<property name="minPoolSize" value="3" />
</bean>

<!-- 配置Hibernate-->
<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource">
<ref bean="dataSource" /><!-- 引用数据源 -->
</property>
<property name="hibernateProperties"><!-- 配置Hibernate的属性 -->
<props>
<prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop>
<prop key="hibernate.show_sql">true</prop>
<prop key="hibernate.jdbc.fetch_size">50</prop>
<prop key="hibernate.jdbc.batch_size">50</prop>
<prop key="hibernate.cglib.use_reflection_optimizer">false</prop>
<prop key="hibernate.cache.provider_class">
org.hibernate.cache.EhCacheProvider
</prop>
</props>
</property>
<property name="mappingResources">
<list>
<value>com/czd/entityUser.hbm.xml</value> 

..................
</list>
</property>
</bean>

配置好数据源和sessionFactory后,接下来就是给DAO注入sessionFactory:

同样的在application.xml文件中配置,例如:

<bean id="userDao" class="com.czd.dao.UserDao">
<property name="sessionFactory">
<ref bean="sessionFactory" />
</property>
</bean>

此时就可以在userDao中获取到sessionFactory了。

最后userDao继承HibernateDaoSupport,然后只需要在方法中通过getSession()取得session对象就可以对数据库进行CRUD。


0 0
原创粉丝点击