<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    J2EE社區(qū)

    茍有恒,何必三更起五更眠;
    最無(wú)益,只怕一日曝十日寒.
    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來(lái)統(tǒng)一管理連接池,也就是統(tǒng)一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語(yǔ)句 -->
                    
    <prop key="hibernate.show_sql">true</prop>
                    
    <!-- 解決提交亂碼問題 -->
                    
    <prop key="connection.useUnicode">true</prop>
                    
    <prop key="connection.characterEncoding">utf-8</prop>
                    
    <!-- 格式化sql語(yǔ)句 -->
                    
    <prop key="hibernate.format_sql">true</prop>
                    
    <prop key="hibernate.order_updates">true</prop>
                    
    <!-- 事務(wù)自動(dòng)管理 -->
                    
    <prop key="hibernate.connection.release_mode">
                        after_transaction
                    
    </prop>
                
    </props>
            
    </property>

            
    <property name="mappingResources">
                
    <list></list>
            
    </property>
        
    </bean>
     2、tomcat下配置連接池
        Spring不通過用tomcat中配置的JNDI來(lái)連接,但是它也是通過用commons.dbcp.jar連接池來(lái)管理的,也可以通過其他的開源連接池工具如: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>

    二、測(cè)試配置連接池
    1、測(cè)試tomcat連接池
        *>不用Spring管理的tomcat連接池測(cè)試代碼(只能在jsp里面測(cè)試):            
    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(
    "已經(jīng)得到連接");
        } 
    else {
            System.out.println(
    "沒有得到連接");
        }
        *>用Spring管理tomcat連接池的測(cè)試代碼:    
     //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.測(cè)試Spring連接池
        其實(shí)測(cè)試Spring連接池的代碼和上面Spring管理tomcat連接池測(cè)試代碼一樣:    
    //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連接池因?yàn)榕渲胻omcat下面的,所有最好用jsp或者maven(模擬窗口測(cè)試方法)來(lái)測(cè)試,但是跟我們的測(cè)試帶了很多的不變啊,若能在普通java application或者junit方法測(cè)試就不容易,也不知道雜寫,若高手知道請(qǐng)指教
        而Spring連接池與HTTP協(xié)議無(wú)關(guān),可直接通過java application或junit直接使用,大大地方便了測(cè)試和使用.
        在效率方面,我倒沒認(rèn)真測(cè)試有什么不同,但是我覺得,都是用的第三方連接池管理,應(yīng)該差別不大,有不同見解的朋友請(qǐng)指出來(lái),共同學(xué)習(xí)!!


    名稱: ?4C.ESL | .↗Evon
    口號(hào): 遇到新問題?先要尋找一個(gè)方案乄而不是創(chuàng)造一個(gè)方案こ
    mail: 聯(lián)系我


    Feedback

    # re: 配置java連接池 tomcat、Spring配置文件兩種  回復(fù)  更多評(píng)論   

    2009-11-04 14:41 by 咖啡妝
    最后記得close connection 小心數(shù)據(jù)庫(kù)實(shí)例到達(dá)上線,造成死鎖!

    # re: 配置java連接池 tomcat、Spring配置文件兩種  回復(fù)  更多評(píng)論   

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

    # re: 配置java連接池 tomcat、Spring配置文件兩種  回復(fù)  更多評(píng)論   

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

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

    2010-01-14 09:49 by dan
    學(xué)習(xí)了!!!

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

    2013-08-06 12:15 by only
    好好學(xué)習(xí)!
    主站蜘蛛池模板: 免费大黄网站在线看| 免费人成网站在线观看10分钟| 特黄aa级毛片免费视频播放| 久久亚洲精品高潮综合色a片| 日韩亚洲不卡在线视频中文字幕在线观看| 亚洲天堂中文字幕在线观看| 亚洲欧洲自拍拍偷午夜色| 亚洲图片中文字幕| 亚洲AV无码一区二区三区在线 | 午夜理伦剧场免费| 国产激情免费视频在线观看| 无码人妻久久一区二区三区免费| 日韩成人免费视频| 亚洲人成免费网站| 69成人免费视频无码专区| 免费观看大片毛片| 亚洲 小说区 图片区 都市| 国内精品久久久久久久亚洲| 亚洲AV无码国产丝袜在线观看| 亚洲乱亚洲乱淫久久| 亚洲an日韩专区在线| 亚洲AV无码成人网站在线观看| 羞羞漫画页面免费入口欢迎你| 一级做受视频免费是看美女| 国内精品一级毛片免费看| 亚洲视频在线免费看| 免费观看毛片视频| 亚洲午夜福利精品久久 | 卡1卡2卡3卡4卡5免费视频| 国产伦精品一区二区三区免费迷| 国产成人精品曰本亚洲79ren| 亚洲成a人片在线观看无码专区| 久久亚洲国产精品成人AV秋霞| 亚洲AV无码国产精品色| 免费人成视频在线播放| 免费人成黄页在线观看日本| 国产2021精品视频免费播放| 日本免费高清一本视频| 亚洲人成色777777在线观看| 亚洲午夜电影在线观看| 美女免费视频一区二区|