詳解IDEA2020新建spring項目和c3p0連接池的創(chuàng)建和使用
前言
C3P0是一個開源的JDBC連接池,它實現(xiàn)了數(shù)據(jù)源和JNDI綁定,支持JDBC3規(guī)范和JDBC2的標準擴展,目前使用它的開源項目有Hibernate,Spring等。
1、環(huán)境準備:maven配置
打開idea,點擊“+”新建項目,選擇Spring,點擊next,填寫項目的名稱,點擊finish,新的Spring項目就建好了


新建好的spring項目目錄如下,這里可以看到是沒有pom.xml文件的,為了更好管理spring項目,需要配置maven環(huán)境。點擊項目上方的file/settings

點擊Build,Execution,Deployment/Build Tools/Maven,將User settings file和Local repository這兩處的地址改成下載的maven安裝包的地址以及安裝包下settings.xml配置文件的地址,點擊OK

右擊項目名稱,點擊Add Framework Support,勾選Maven,點擊OK


添加了maven之后可以看到項目出現(xiàn)了熟悉的maven項目的文件夾和pom.xml文件

2、導(dǎo)入jar包:c3p0-0.9.5.4.jar和mysql-connector-java.jar
右擊項目名稱,點擊Open Modules Settings

點擊Modules/Dependencies,點擊右側(cè)“+”號,jars or directories

選擇jar包存儲的路徑,選中需要導(dǎo)入的jar包,點擊OK

可以看到目錄下出現(xiàn)了剛剛導(dǎo)入的jar包,勾選它們點擊OK

打開pom.xml文件,在maven里添加mysql和c3p0這兩個依賴

3、編寫測試類測試連接
c3p0創(chuàng)建數(shù)據(jù)源的方法有兩種:一是直接使用set將屬性設(shè)置到數(shù)據(jù)源中,若后續(xù)需要更改只能通過源碼更改,二是將屬性寫入properties文件,通過加載properties配置文件的形式創(chuàng)建數(shù)據(jù)源,可讀寫能力更強
首先介紹第一種方法,本測試類寫在Test文件夾下,主要需要注意的點有:
①driveClass現(xiàn)在都更新為com.mysql.cj.jdbc.Driver,而并非以前用的com.mysql.jdbc.Driver
②jdbcUrl中一定要在末尾加serverTimezone=UTC這一語句,不然就會報Caused by: com.mysql.cj.exceptions.InvalidConnectionAttributeException: The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized or represents more than one time zone時間區(qū)錯誤
@Test
//測試手動創(chuàng)建c3p0數(shù)據(jù)源
public void test1() throws PropertyVetoException, SQLException {
ComboPooledDataSource dataSource = new ComboPooledDataSource();
dataSource.setDriverClass("com.mysql.cj.jdbc.Driver");
dataSource.setJdbcUrl("jdbc:mysql://localhost:3306/spring-test?useUnicode=true&characterEncoding=utf-8&serverTimezone=UTC");
dataSource.setUser("root");
dataSource.setPassword("");
Connection connection = dataSource.getConnection();
System.out.println(connection);
connection.close();
}
運行后的結(jié)果如下,可以看到成功輸出了connection對象的地址,說明連接創(chuàng)建成功

第二種方法,先在test文件夾的resources下新建properties配置文件,然后在properties里設(shè)置以下屬性值

jdbc.driver=com.mysql.cj.jdbc.Driver jdbc.url=jdbc:mysql://localhost:3306/spring-test?useUnicode=true&characterEncoding=utf-8&serverTimezone=UTC jdbc.username=root jdbc.password=
本測試方法和第一種測試方法寫在同一個測試類里
@Test
//測試手動創(chuàng)建c3p0數(shù)據(jù)源(加載properties配置文件形式)
public void test2() throws PropertyVetoException, SQLException {
//讀取配置文件
ResourceBundle rb = ResourceBundle.getBundle("jdbc");
String driver = rb.getString("jdbc.driver");
String url = rb.getString("jdbc.url");
String username = rb.getString("jdbc.username");
String password = rb.getString("jdbc.password");
//創(chuàng)建數(shù)據(jù)源對象,設(shè)置連接參數(shù)
ComboPooledDataSource dataSource = new ComboPooledDataSource();
dataSource.setDriverClass(driver);
dataSource.setJdbcUrl(url);
dataSource.setUser(username);
dataSource.setPassword(password);
Connection connection = dataSource.getConnection();
System.out.println(connection);
connection.close();
}
運行之后可以看到同樣成功輸出connection對象的地址,說明連接創(chuàng)建成功

到此這篇關(guān)于詳解IDEA2020新建spring項目和c3p0連接池的創(chuàng)建和使用的文章就介紹到這了,更多相關(guān)spring創(chuàng)建c3p0連接池內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java中Set與List的關(guān)系與區(qū)別介紹
這篇文章主要介紹了Java中Set與List的關(guān)系與區(qū)別介紹,本文總結(jié)它們兩個接口都是繼承自Collection、它們之間的存儲方式不一樣,需要的朋友可以參考下2015-03-03
阿里資深技術(shù)專家:在各階段中3年經(jīng)驗的java程序員應(yīng)該具備哪些技術(shù)能力
這篇文章主要介紹了阿里資深技術(shù)專家:在各階段中3年經(jīng)驗的java程序員應(yīng)該具備哪些技術(shù)能力,本文給大家列舉了一些內(nèi)容,大家可以根據(jù)自己需要有方法的掌握,感興趣的朋友跟隨小編一起看看吧2020-07-07
java中的HashSet與 == 和 equals的區(qū)別示例解析
HashSet是Java中基于哈希表實現(xiàn)的集合類,特點包括:元素唯一、無序和可包含null,本文給大家介紹java中的HashSet與 == 和 equals的區(qū)別,感興趣的朋友一起看看吧2025-02-02

