一.早期datasource设定:
在server.xml中声明:
<Context docBase="ssh" path="/ssh" reloadable="true" source="org.eclipse.jst.jee.server:ssh">
<Resource name="jdbc/TestDB" auth="Container" type="javax.sql.DataSource"
maxActive="100" maxIdle="30" maxWait="10000"
username="root" password="root" driverClassName="com.mysql.jdbc.Driver"
url="jdbc:mysql://localhost:3306/test"/>
</Context>
然后在web.xml中引用:
<resource-ref>
<description>DB Connection</description>
<res-ref-name>jdbc/TestDB</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
</resource-ref>
使用的时候lookup。
二.datasource在整合时的设定方式
在用spring和hibernate整合时datasource可以以两种方式获得:
1.在spring中按常规的bean来定义
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<property name="driverClassName" value="org.gjt.mm.mysql.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/dbname?useUnicode=true&characterEncoding=UTF-8"/>
<property name="username" value="root"/>
<property name="password" value="123456"/>
<!-- 连接池启动时的初始值 -->
<property name="initialSize" value="1"/>
<!-- 连接池的最大值 -->
<property name="maxActive" value="500"/>
<!-- 最大空闲值.当经过一个高峰时间后,连接池可以慢慢将已经用不到的连接慢慢释放一部分,一直减少到maxIdle为止 -->
<property name="maxIdle" value="2"/>
<!-- 最小空闲值.当空闲的连接数少于阀值时,连接池就会预申请去一些连接,以免洪峰来时来不及申请 -->
<property name="minIdle" value="1"/>
</bean>
2.通过jndi获得容器里的datasource(前提是已经在容器里注册好了对应的datasource)
<bean id="dataSource" class="org.springframework.jndi.JndiObjectFactoryBean">
<property name="jndiName"><value>java:comp/env/jdbc/aurora_contact_web</value></property>
</bean>
或者
<jee:jndi-lookup id="dataSource" jndi-name="java:comp/env/jdbc/aurora"/>
三.sessionfactory的设定:
用properties方式:
<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource" ref="myds" />
<property name="mappingDirectoryLocations">
<list>
<value>classpath:/com/dao</value>
</list>
</property>
<property name="hibernateProperties">
<value>
hibernate.dialect=org.hibernate.dialect.MySQLDialect
hibernate.hbm2ddl.auto=update
hibernate.show_sql=false
hibernate.format_sql=false
</value>
</property>
</bean>
cfg.xml方式:略
四.除了hibernate的required和hibernate核心包外,还要将jpa下的hibernate-jpa-2.0-api-1.0.1.Final.jar加入。
否则报:
java.lang.NoClassDefFoundError: javax/persistence/EntityListeners
spring和hibernate整合
猜你喜欢
转载自huzhanchi.iteye.com/blog/2070613
今日推荐
周排行