Posted on 2009-11-04 14:36
xcp 閱讀(10345)
評論(5) 編輯 收藏 所屬分類:
JAVA 、
Spring
一、首先配置連接池
1、tomcat下配置連接池
*>在tomcat下的context.xml配置連接池代碼
<Resource
name="jdbc/sqlserver" //連接池名稱
type="javax.sql.DataSource"
password="syl6413"
driverClassName="com.microsoft.sqlserver.jdbc.SQLServerDriver"
maxIdle="5"
maxWait="5000"
username="sa"
url="jdbc:sqlserver://192.168.0.9:1433; DatabaseName=disasterSystem"
maxActive="10"/>
*>tomcat連接池中配置web.xml代碼
<!-- DataSource -->
<resource-ref>
<description>SQLServer2005 Datasource disasterSystem</description>
<res-ref-name>jdbc/sqlserver</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
</resource-ref>
*>在Spring配置tomcat連接池的JNDI代碼
<bean id="dataSource" class="org.springframework.jndi.JndiObjectFactoryBean">
<property name="jndiName" value="java:comp/env/jdbc/sqlserver">
</property>
</bean>
自此tomcat連接池已配置完畢,若不用Spring管理連接池,也可以不配Spring,這樣即可以在程序中使用tomcat連接池了.若使用Spring來統一管理連接池,也就是統一SessionFactory,配置方式如下:
<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource">
<ref bean="dataSource" />
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">
org.hibernate.dialect.SQLServerDialect
</prop>
<prop key="hibernate.connection.autocommit">true</prop>
<!-- 顯示sql語句 -->
<prop key="hibernate.show_sql">true</prop>
<!-- 解決提交亂碼問題 -->
<prop key="connection.useUnicode">true</prop>
<prop key="connection.characterEncoding">utf-8</prop>
<!-- 格式化sql語句 -->
<prop key="hibernate.format_sql">true</prop>
<prop key="hibernate.order_updates">true</prop>
<!-- 事務自動管理 -->
<prop key="hibernate.connection.release_mode">
after_transaction
</prop>
</props>
</property>
<property name="mappingResources">
<list></list>
</property>
</bean>
2、tomcat下配置連接池
Spring不通過用tomcat中配置的JNDI來連接,但是它也是通過用commons.dbcp.jar連接池來管理的,也可以通過其他的開源連接池工具如:C3P0等。配置又分為兩種,具體代碼如下:
*>一種是直接配置applicationContext.xml
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName" value="oracle.jdbc.driver.OracleDriver">
</property>
<property name="url" value="jdbc:oracle:thin:@localhost:1521:SJY">
</property>
<property name="username" value="**"></property>
<property name="password" value="**"></property>
</bean>
*>另一種是通過perportise配置文件:datasource.properties再通過applicationContext.xml得到
datasource.properties代碼:
datasource.driverClassName=com.microsoft.sqlserver.jdbc.SQLServerDriver
datasource.url=jdbc:sqlserver://192.168.0.9:1433;DatabaseName=disasterSystem
datasource.username=sa
datasource.password=syl6413
datasource.maxActive=10
datasource.maxIdle=5
datasource.maxWait=5000
datasource.defaultAutoCommit=true
applicationContext.xml代碼:
<bean id="placeholderConfig" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="location">
<value>classpath:/datasource.properties</value>
</property>
</bean>
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName">
<value>${datasource.driverClassName}</value>
</property>
<property name="url">
<value>${datasource.url}</value>
</property>
<property name="username">
<value>${datasource.username}</value>
</property>
<property name="password">
<value>${datasource.password}</value>
</property>
<property name="maxActive">
<value>${datasource.maxActive}</value>
</property>
<property name="maxIdle">
<value>${datasource.maxIdle}</value>
</property>
<property name="maxWait">
<value>${datasource.maxWait}</value>
</property>
<property name="defaultAutoCommit">
<value>${datasource.defaultAutoCommit}</value>
</property>
</bean>
二、測試配置連接池
1、測試tomcat連接池
*>不用Spring管理的tomcat連接池測試代碼(只能在jsp里面測試):
Context initContext = new InitialContext();
Context envContext =(Context)initContext.lookup("java:comp/env");
DataSource ds = (DataSource) envContext.lookup("jdbc/sqlserver");
Connection con = ds.getConnection();
if (con != null) {
System.out.println("已經得到連接");
} else {
System.out.println("沒有得到連接");
}
*>用Spring管理tomcat連接池的測試代碼:
//ApplicationContext ctx = new FileSystemXmlApplicationContext("src/applicationContext.xml");//兩種得到bean工廠的代碼,任選其一
ApplicationContext ctx = new ClassPathXmlApplicationContext("applicationContext.xml");
DataSource ds = (DataSource) ctx.getBean("dataSource");
Connection con = ds.getConnection();
if(con != null){
System.out.println("連接成功");
}else{
System.out.println("連接不成功");
}
2.測試Spring連接池
其實測試Spring連接池的代碼和上面Spring管理tomcat連接池測試代碼一樣:
//ApplicationContext ctx = new FileSystemXmlApplicationContext("src/applicationContext.xml");//兩種得到bean工廠的代碼,任選其一
ApplicationContext ctx = new ClassPathXmlApplicationContext("applicationContext.xml");
DataSource ds = (DataSource) ctx.getBean("dataSource");
Connection con = ds.getConnection();
if(con != null){
System.out.println("連接成功");
}else{
System.out.println("連接不成功");
}
三、兩種連接池比較
tomcat連接池因為配置tomcat下面的,所有最好用jsp或者maven(模擬窗口測試方法)來測試,但是跟我們的測試帶了很多的不變啊,若能在普通java application或者junit方法測試就不容易,也不知道雜寫,若高手知道請指教
而Spring連接池與HTTP協議無關,可直接通過java application或junit直接使用,大大地方便了測試和使用.
在效率方面,我倒沒認真測試有什么不同,但是我覺得,都是用的第三方連接池管理,應該差別不大,有不同見解的朋友請指出來,共同學習!!
名稱: ?4C.ESL | .↗Evon
口號: 遇到新問題?先要尋找一個方案乄而不是創造一個方案こ
mail: 聯系我