J2EE社區

          茍有恒,何必三更起五更眠;
          最無益,只怕一日曝十日寒.
          posts - 241, comments - 318, trackbacks - 0, articles - 16

          一、首先配置連接池
          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: 聯系我


          Feedback

          # re: 配置java連接池 tomcat、Spring配置文件兩種  回復  更多評論   

          2009-11-04 14:41 by 咖啡妝
          最后記得close connection 小心數據庫實例到達上線,造成死鎖!

          # re: 配置java連接池 tomcat、Spring配置文件兩種  回復  更多評論   

          2009-11-04 19:19 by xcp
          @咖啡妝
          恩.那是肯定的.一般我都用Spring提供的opensessioninviewfilter 來管理Session

          # re: 配置java連接池 tomcat、Spring配置文件兩種  回復  更多評論   

          2009-11-05 13:15 by mingruofei
          收藏了

          # re: 配置java連接池 tomcat方式、Spring方式配置的比較(修正版)[未登錄]  回復  更多評論   

          2010-01-14 09:49 by dan
          學習了!!!

          # re: 配置java連接池 tomcat方式、Spring方式配置的比較(修正版)  回復  更多評論   

          2013-08-06 12:15 by only
          好好學習!
          主站蜘蛛池模板: 阿拉善右旗| 株洲市| 光山县| 青铜峡市| 鸡西市| 怀安县| 金乡县| 旬阳县| 彭泽县| 阳谷县| 紫金县| 奉节县| 那曲县| 都匀市| 尼木县| 璧山县| 嘉禾县| 冷水江市| 宜城市| 上高县| 大同市| 水城县| 孝昌县| 广灵县| 洛扎县| 建湖县| 家居| 富宁县| 石台县| 宕昌县| 大冶市| 乌鲁木齐市| 望城县| 丰原市| 乐清市| 双峰县| 长宁县| 福贡县| 青海省| 文水县| 准格尔旗|