日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 前端技术 > javascript >内容正文

javascript

Spring中配置数据源的4种形式

發(fā)布時(shí)間:2025/3/20 javascript 47 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Spring中配置数据源的4种形式 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

轉(zhuǎn)自:https://blog.csdn.net/qqqqqq654/article/details/52462203??

不管采用何種持久化技術(shù),都需要定義數(shù)據(jù)源。Spring中提供了4種不同形式的數(shù)據(jù)源配置方式:

spring自帶的數(shù)據(jù)源(DriverManagerDataSource),DBCP數(shù)據(jù)源,C3P0數(shù)據(jù)源,JNDI數(shù)據(jù)源。

1.spring自帶的數(shù)據(jù)源

DriverManagerDataSource

XML代碼:

?

[html] view plaincopy
  • <bean?id="dataSource"?????
  • ??????class="org.springframework.jdbc.datasource.DriverManagerDataSource">?????
  • ????<property?name="driverClassName"?value="oracle.jdbc.driver.OracleDriver"?/>??
  • ????<property?name="url"?value="jdbc:oracle:thin:@172.19.34.6:1521:ORCL"?/>??
  • ????<property?name="username"?value="orclight"?/>?????
  • ????<property?name="password"?value="123456"?/>??
  • </bean>??
  • 2.DBCP數(shù)據(jù)源

    ? ??DBCP的配置依賴于2個(gè)jar包commons-dbcp.jar,commons-pool.jar。

    XML代碼:

    ?

    [html] view plaincopy
  • <bean?id="dataSource"?class="org.apache.commons.dbcp.BasicDataSource"?????????
  • ????????destroy-method="close">?????????
  • ????<property?name="driverClassName"?value="oracle.jdbc.driver.OracleDriver"?/>??
  • ????<property?name="url"?value="jdbc:oracle:thin:@172.19.34.6:1521:ORCL"?/>??
  • ????<property?name="username"?value="orclight"?/>?????
  • ????<property?name="password"?value="123456"?/>????????
  • </bean>???
  • 上面代碼的解釋:

    BasicDataSource提供了close()方法關(guān)閉數(shù)據(jù)源,所以必須設(shè)定destroy-method=”close”屬性, 以便Spring容器關(guān)閉時(shí),數(shù)據(jù)源能夠正常關(guān)閉。除以上必須的數(shù)據(jù)源屬性外,還有一些常用的屬性:?
    ? ? defaultAutoCommit:設(shè)置從數(shù)據(jù)源中返回的連接是否采用自動(dòng)提交機(jī)制,默認(rèn)值為 true;?
    ? ? defaultReadOnly:設(shè)置數(shù)據(jù)源是否僅能執(zhí)行只讀操作, 默認(rèn)值為 false;?
    ? ? maxActive:最大連接數(shù)據(jù)庫(kù)連接數(shù),設(shè)置為0時(shí),表示沒(méi)有限制;?
    ? ? maxIdle:最大等待連接中的數(shù)量,設(shè)置為0時(shí),表示沒(méi)有限制;?
    ? ? maxWait:最大等待秒數(shù),單位為毫秒, 超過(guò)時(shí)間會(huì)報(bào)出錯(cuò)誤信息;?
    ? ? validationQuery:用于驗(yàn)證連接是否成功的查詢SQL語(yǔ)句,SQL語(yǔ)句必須至少要返回一行數(shù)據(jù), 如你可以簡(jiǎn)單地設(shè)置為:“select count(*) from user”;?
    ? ? removeAbandoned:是否自我中斷,默認(rèn)是 false ;?
    ? ? removeAbandonedTimeout:幾秒后數(shù)據(jù)連接會(huì)自動(dòng)斷開,在removeAbandoned為true,提供該值;?
    ? ? logAbandoned:是否記錄中斷事件, 默認(rèn)為 false;

    3.C3P0數(shù)據(jù)源

    ? ???C3P0是一個(gè)開放源代碼的JDBC數(shù)據(jù)源實(shí)現(xiàn)項(xiàng)目,C3P0依賴于jar包c3p0.jar

    XML代碼:

    ?

    [html] view plaincopy
  • <bean?id="dataSource"?class="com.mchange.v2.c3p0.ComboPooledDataSource"?????????
  • ????????????destroy-method="close">????????
  • ????????<property?name="driverClass"?value="?oracle.jdbc.driver.OracleDriver?"/>????????
  • ????????<property?name="jdbcUrl"?value="jdbc:oracle:thin:@172.19.34.6:1521:ORCL"/>????????
  • ????????<property?name="user"?value="orclight"/>????????
  • ????????<property?name="password"?value="123456"/>????????
  • ????</bean>???
  • ComboPooledDataSource和BasicDataSource一樣提供了一個(gè)用于關(guān)閉數(shù)據(jù)源的close()方法,這樣我們就可以保證Spring容器關(guān)閉時(shí)數(shù)據(jù)源能夠成功釋放。

    ? ? C3P0擁有比DBCP更豐富的配置屬性,通過(guò)這些屬性,可以對(duì)數(shù)據(jù)源進(jìn)行各種有效的控制:
    ? ? acquireIncrement:當(dāng)連接池中的連接用完時(shí),C3P0一次性創(chuàng)建新連接的數(shù)目;
    ? ? acquireRetryAttempts:定義在從數(shù)據(jù)庫(kù)獲取新連接失敗后重復(fù)嘗試獲取的次數(shù),默認(rèn)為30;
    ? ? acquireRetryDelay:兩次連接中間隔時(shí)間,單位毫秒,默認(rèn)為1000;
    ? ? autoCommitOnClose:連接關(guān)閉時(shí)默認(rèn)將所有未提交的操作回滾。默認(rèn)為false;
    ? ? automaticTestTable: C3P0將建一張名為Test的空表,并使用其自帶的查詢語(yǔ)句進(jìn)行測(cè)試。如果定義了這個(gè)參數(shù),那么屬性preferredTestQuery將被忽略。你 不能在這張Test表上進(jìn)行任何操作,它將中為C3P0測(cè)試所用,默認(rèn)為null;
    ? ? breakAfterAcquireFailure:獲取連接失敗將會(huì)引起所有等待獲取連接的線程拋出異常。但是數(shù)據(jù)源仍有效保留,并在下次調(diào) ? 用getConnection()的時(shí)候繼續(xù)嘗試獲取連接。如果設(shè)為true,那么在嘗試獲取連接失敗后該數(shù)據(jù)源將申明已斷開并永久關(guān)閉。默認(rèn)為 false;
    ? ? checkoutTimeout:當(dāng)連接池用完時(shí)客戶端調(diào)用getConnection()后等待獲取新連接的時(shí)間,超時(shí)后將拋出SQLException,如設(shè)為0則無(wú)限期等待。單位毫秒,默認(rèn)為0;
    ? ? connectionTesterClassName: 通過(guò)實(shí)現(xiàn)ConnectionTester或QueryConnectionTester的類來(lái)測(cè)試連接,類名需設(shè)置為全限定名。默認(rèn)為 com.mchange.v2.C3P0.impl.DefaultConnectionTester;?
    ? ? idleConnectionTestPeriod:隔多少秒檢查所有連接池中的空閑連接,默認(rèn)為0表示不檢查;
    ? ? initialPoolSize:初始化時(shí)創(chuàng)建的連接數(shù),應(yīng)在minPoolSize與maxPoolSize之間取值。默認(rèn)為3;
    ? ? maxIdleTime:最大空閑時(shí)間,超過(guò)空閑時(shí)間的連接將被丟棄。為0或負(fù)數(shù)則永不丟棄。默認(rèn)為0;
    ? ? maxPoolSize:連接池中保留的最大連接數(shù)。默認(rèn)為15;
    ? ? maxStatements:JDBC的標(biāo)準(zhǔn)參數(shù),用以控制數(shù)據(jù)源內(nèi)加載的PreparedStatement數(shù)量。但由于預(yù)緩存的Statement屬 于單個(gè)Connection而不是整個(gè)連接池。所以設(shè)置這個(gè)參數(shù)需要考慮到多方面的因素,如果maxStatements與 maxStatementsPerConnection均為0,則緩存被關(guān)閉。默認(rèn)為0;
    ? ? maxStatementsPerConnection:連接池內(nèi)單個(gè)連接所擁有的最大緩存Statement數(shù)。默認(rèn)為0;
    ? ? numHelperThreads:C3P0是異步操作的,緩慢的JDBC操作通過(guò)幫助進(jìn)程完成。擴(kuò)展這些操作可以有效的提升性能,通過(guò)多線程實(shí)現(xiàn)多個(gè)操作同時(shí)被執(zhí)行。默認(rèn)為3;
    ? ? preferredTestQuery:定義所有連接測(cè)試都執(zhí)行的測(cè)試語(yǔ)句。在使用連接測(cè)試的情況下這個(gè)參數(shù)能顯著提高測(cè)試速度。測(cè)試的表必須在初始數(shù)據(jù)源的時(shí)候就存在。默認(rèn)為null;
    ? ? propertyCycle: 用戶修改系統(tǒng)配置參數(shù)執(zhí)行前最多等待的秒數(shù)。默認(rèn)為300;
    ? ? testConnectionOnCheckout:因性能消耗大請(qǐng)只在需要的時(shí)候使用它。如果設(shè)為true那么在每個(gè)connection提交的時(shí)候都 將校驗(yàn)其有效性。建議使用idleConnectionTestPeriod或automaticTestTable
    等方法來(lái)提升連接測(cè)試的性能。默認(rèn)為false;
    ? ? testConnectionOnCheckin:如果設(shè)為true那么在取得連接的同時(shí)將校驗(yàn)連接的有效性。默認(rèn)為false。

    4.JNDI數(shù)據(jù)源

    ? ??如果應(yīng)用配置在高性能的應(yīng)用服務(wù)器(如WebLogic或Websphere,tomcat等)上,我們可能更希望使用應(yīng)用服務(wù)器本身提供的數(shù)據(jù)源。應(yīng)用服務(wù)器的數(shù)據(jù)源 使用JNDI開放調(diào)用者使用,Spring為此專門提供引用JNDI資源的JndiObjectFactoryBean類。

    xml 代碼:? ??

    ?

    [html] view plaincopy
  • <bean?id="dataSource"?class="org.springframework.jndi.JndiObjectFactoryBean">????????
  • ????????<property?name="jndiName"?value="java:comp/env/jdbc/orclight"/>????????
  • </bean>??

  • ?

    [html] view plaincopy
  • <beans?xmlns=http://www.springframework.org/schema/beans??????
  • xmlns:xsi=http://www.w3.org/2001/XMLSchema-instance??????
  • xmlns:jee=http://www.springframework.org/schema/jee??????
  • xsi:schemaLocation="http://www.springframework.org/schema/beans???????
  • http://www.springframework.org/schema/beans/spring-beans-2.0.xsd???????
  • http://www.springframework.org/schema/jee??????
  • http://www.springframework.org/schema/jee/spring-jee-2.0.xsd">????????
  • ????<jee:jndi-lookup?id="dataSource"?jndi-name="?java:comp/env/jdbc/orclight"/>????????
  • </beans>?
  • 轉(zhuǎn)載于:https://www.cnblogs.com/sharpest/p/7295031.html

    總結(jié)

    以上是生活随笔為你收集整理的Spring中配置数据源的4种形式的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。