一.早期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整合示例,以一张表的业务操作,来简要说明hibernate和spring的整合,说明spring对HibernateTemplate和调用
Spring与hibernate 整合 简单示例 Spring与hibernate 整合 简单示例
Spring 和Hibernate整合开发的笔记文档和使用的jar包
JavaEE spring和Hibernate整合(没有hibernate.cfg.xml)
struts2和spring和Hibernate的整合包,在MyEclipse中自动导入老是有冲突包。
JavaEE spring和Hibernate整合(有hibernate.cfg.xml)
spring和hibernate整合的优化配置.txt
struts2和spring和hibernate整合所需包集合.rar
Spring+hibernate整合源代码 结束Sping+hibernate 的使用方法 包括演示示例
Spring与Hibernate整合小例子
struts、spring和hibernate整合所需要的常用的包.
spring-Hibernate整合代码测试过程
spring_hibernate整合实例 spring_hibernate整合实例
《疯狂Ajax讲义:Prototype/jQuery+DWR+Spring+Hibernate整合开发》是疯狂Java体系丛书之一,前8章基本以XHTML、JavaScript和DOM编程为主,无须任何基础即可阅读;第9章以后的内容则需要掌握Spring、Hibernate等Java ...
spring与hibernate的整合 spring事务的配置
spring hibernate整合jar包齐全
struts+spring+hibernate整合