




版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
第Java數據庫連接池c3p0介紹詳細說明可參考官網文檔:/projects/c3p0/#configuration
2、原始連接操作
c3p0提供api來訪問原始連接中的非標準接口:
把連接轉成C3P0ProxyConnection
然后調用rawConnectionOperation方法
下面是獲取PostgreSQL
JDBC驅動中CopyManager對象的方法:
Connectionconnection=(C3P0ProxyConnection)c3p0DataSource.getConnection();
C3P0ProxyConnectioncastConnection=(C3P0ProxyConnection)connection;
Methodmethod=BaseConnection.class.getMethod("getCopyAPI",newClass[]{});
CopyManagercopyManager=(CopyManager)castConnection.rawConnectionOperation(method,C3P0ProxyConnection.RAW_CONNECTION,newObject[]{});
3、使用
3.1、直接使用
3.1.1、引入依賴
dependency
groupIdcom.mchange/groupId
artifactIdc3p0/artifactId
version/version
/dependency
3.1.2、使用例子
packagecom.abc.demo.general.dbpool;
importcom.mchange.v2.c3p0.ComboPooledDataSource;
importjava.beans.PropertyVetoException;
importjava.sql.Connection;
importjava.sql.ResultSet;
importjava.sql.SQLException;
importjava.sql.Statement;
publicclassC3p0Case{
publicstaticvoidmain(String[]args)throwsPropertyVetoException{
ComboPooledDataSourcecomboPooledDataSource=newComboPooledDataSource();
comboPooledDataSource.setDriverClass("com.mysql.cj.jdbc.Driver");
comboPooledDataSource.setJdbcUrl("jdbc:mysql://1:3306/mydbuseUnicode=truecharacterEncoding=UTF-8");
comboPooledDataSource.setUser("root");
comboPooledDataSource.setPassword("123456");
comboPooledDataSource.setInitialPoolSize(2);
comboPooledDataSource.setMinPoolSize(2);
comboPooledDataSource.setMaxPoolSize(10);
comboPooledDataSource.setPreferredTestQuery("select1");
comboPooledDataSource.setIdleConnectionTestPeriod(60);
comboPooledDataSource.setTestConnectionOnCheckout(true);
comboPooledDataSource.setCheckoutTimeout(1000*30);
Connectionconnection=null;
Statementst=null;
ResultSetrs=null;
try{
connection=comboPooledDataSource.getConnection();
st=connection.createStatement();
rs=st.executeQuery("selectversion()");
if(rs.next()){
System.out.println(rs.getString(1));
}catch(SQLExceptione){
e.printStackTrace();
}finally{
close(connection);
//實際使用中一般是在應用啟動時初始化數據源,應用從數據源中獲取連接;并不會關閉數據源。
comboPooledDataSource.close();
privatestaticvoidclose(Connectionconnection){
if(connection!=null){
try{
connection.close();
}catch(SQLExceptione){
e.printStackTrace();
}
3.2、在SpringBoot中使用
3.1.1、引入依賴
parent
groupIdorg.springframework.boot/groupId
artifactIdspring-boot-starter-parent/artifactId
version2.3.12.RELEASE/version
relativePath/
/parent
dependencies
dependency
groupIdorg.springframework.boot/groupId
artifactIdspring-boot-starter-web/artifactId
/dependency
dependency
groupIdorg.springframework/groupId
artifactIdspring-jdbc/artifactId
/dependency
dependency
groupIdcom.mchange/groupId
artifactIdc3p0/artifactId
version/version
/dependency
dependency
groupIdmysql/groupId
artifactIdmysql-connector-java/artifactId
/dependency
/dependencies
3.1.2、單數據源
application.yml配置:
spring:
datasource:
c3p0:
driver-class:com.mysql.cj.jdbc.Driver
jdbc-url:jdbc:mysql://1:3306/myDbuseUnicode=truecharacterEncoding=UTF-8
user:root
password:123456
initial-pool-size:2
min-pool-size:2
max-pool-size:10
preferred-test-query:select1
idle-connection-test-period:60
test-connection-on-checkout:true
checkout-timeout:30000
數據源配置類:
packagecom.abc.demo.config;
importcom.mchange.v2.c3p0.ComboPooledDataSource;
importperties.ConfigurationProperties;
importorg.springframework.boot.jdbc.DataSourceBuilder;
importorg.springframework.context.annotation.Bean;
importorg.springframework.context.annotation.Configuration;
importjavax.sql.DataSource;
@Configuration
publicclassDataSourceConfig{
@Bean("dataSource")
@ConfigurationProperties(prefix="spring.datasource.c3p0")
publicDataSourcedataSource1(){
returnDataSourceBuilder.create().type(ComboPooledDataSource.class).build();
}
使用:
@Autowired
privateDataSourcedataSource;
3.1.3、多數據源
application.yml配置:
spring:
datasource:
c3p0:
db1:
driver-class:com.mysql.cj.jdbc.Driver
jdbc-url:jdbc:mysql://1:3306/myDbuseUnicode=truecharacterEncoding=UTF-8
user:root
password:InsYR0ot187!
initial-pool-size:2
min-pool-size:2
max-pool-size:10
preferred-test-query:select1
idle-connection-test-period:60
test-connection-on-checkout:true
checkout-timeout:30000
db2:
driver-class:com.mysql.cj.jdbc.Driver
jdbc-url:jdbc:mysql://2:3306/myDbuseUnicode=truecharacterEncoding=UTF-8
user:root
password:InsYR0ot187!
initial-pool-size:2
min-pool-size:2
max-pool-size:10
preferred-test-query:select1
idle-connection-test-period:60
test-connection-on-checkout:true
checkout-timeout:30000
數據源配置類:
packagecom.abc.demo.config;
importcom.mchange.v2.c3p0.ComboPooledDataSource;
importperties.ConfigurationProperties;
importorg.springframework.boot.jdbc.DataSourceBuilder;
importorg.springframework.context.annotation.Bean;
importorg.springframework.context.annotation.Configuration;
importjavax.sql.DataSource;
@Configuration
publicclassDataSourceConfig{
@Bean("dataSource1")
@ConfigurationProperties(prefix="spring.datasource.c3p0.db1")
publicDataSourcedataSource1(){
returnDataSourceBuilder.create().type(ComboPooledDataSource.class).bui
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- JG/T 3025-1995Π 形鋼筋混凝土天窗架
- GB/T 4353-2022載客汽車運行燃料消耗量
- DZ 10-1982金剛石鉆探單動雙層巖心管結構型式和基本參數
- CJ/T 264-2007水處理用橡膠膜微孔曝氣器
- CJ/T 164-2014節(jié)水型生活用水器具
- 中級社會工作者團隊建設試題及答案
- 二級考試復習計劃制定試題及答案
- 系統分析師學習計劃及試題與答案分享
- 構建2025年網絡規(guī)劃設計師必會的知識點與試題及答案
- 高考語文聯考試題及答案
- 分離工程試習題庫-葉慶國
- 2021人教版新教材高中英語必修三全冊課文翻譯(中英文Word)
- 寧夏回族自治區(qū)中衛(wèi)市各縣區(qū)鄉(xiāng)鎮(zhèn)行政村村莊村名居民村民委員會明細及行政區(qū)劃代碼
- rg-wall1600系列下一代防火墻命令手冊
- 噴淋系統調試報告doc
- 科研經費審計報告模板
- DB4416∕T 5-2021 地理標志產品 河源米粉
- 雨季監(jiān)理實施細則
- 課件:基礎生命支持
- 分層審核檢查表LPA全套案例
- 柔版印刷常見故障及解決辦法
評論
0/150
提交評論