欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解IDEA2020新建spring項(xiàng)目和c3p0連接池的創(chuàng)建和使用

 更新時(shí)間:2021年08月10日 10:26:10   作者:D_gloria?  
C3P0是一個(gè)開源的JDBC連接池,它實(shí)現(xiàn)了數(shù)據(jù)源和JNDI綁定,本文就使用Spring實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

前言

        C3P0是一個(gè)開源的JDBC連接池,它實(shí)現(xiàn)了數(shù)據(jù)源和JNDI綁定,支持JDBC3規(guī)范和JDBC2的標(biāo)準(zhǔn)擴(kuò)展,目前使用它的開源項(xiàng)目有Hibernate,Spring等。

 1、環(huán)境準(zhǔn)備:maven配置

         打開idea,點(diǎn)擊“+”新建項(xiàng)目,選擇Spring,點(diǎn)擊next,填寫項(xiàng)目的名稱,點(diǎn)擊finish,新的Spring項(xiàng)目就建好了

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

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

        右擊項(xiàng)目名稱,點(diǎn)擊Add Framework Support,勾選Maven,點(diǎn)擊OK

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

2、導(dǎo)入jar包:c3p0-0.9.5.4.jar和mysql-connector-java.jar

         右擊項(xiàng)目名稱,點(diǎn)擊Open Modules Settings

         點(diǎn)擊Modules/Dependencies,點(diǎn)擊右側(cè)“+”號(hào),jars or directories

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

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

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

 3、編寫測(cè)試類測(cè)試連接

        c3p0創(chuàng)建數(shù)據(jù)源的方法有兩種:一是直接使用set將屬性設(shè)置到數(shù)據(jù)源中,若后續(xù)需要更改只能通過源碼更改,二是將屬性寫入properties文件,通過加載properties配置文件的形式創(chuàng)建數(shù)據(jù)源,可讀寫能力更強(qiáng)

        首先介紹第一種方法,本測(cè)試類寫在Test文件夾下,主要需要注意的點(diǎn)有:

①driveClass現(xiàn)在都更新為com.mysql.cj.jdbc.Driver,而并非以前用的com.mysql.jdbc.Driver

②jdbcUrl中一定要在末尾加serverTimezone=UTC這一語句,不然就會(huì)報(bào)Caused by: com.mysql.cj.exceptions.InvalidConnectionAttributeException: The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized or represents more than one time zone時(shí)間區(qū)錯(cuò)誤

@Test
//測(cè)試手動(dòng)創(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();
}

        運(yùn)行后的結(jié)果如下,可以看到成功輸出了connection對(duì)象的地址,說明連接創(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=

         本測(cè)試方法和第一種測(cè)試方法寫在同一個(gè)測(cè)試類里

@Test
//測(cè)試手動(dòng)創(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ù)源對(duì)象,設(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();
}

         運(yùn)行之后可以看到同樣成功輸出connection對(duì)象的地址,說明連接創(chuàng)建成功

到此這篇關(guān)于詳解IDEA2020新建spring項(xiàng)目和c3p0連接池的創(chuàng)建和使用的文章就介紹到這了,更多相關(guān)spring創(chuàng)建c3p0連接池內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 使用Spirng Boot Admin監(jiān)控Spring Cloud應(yīng)用項(xiàng)目

    使用Spirng Boot Admin監(jiān)控Spring Cloud應(yīng)用項(xiàng)目

    這篇文章主要介紹了使用Spirng Boot Admin監(jiān)控Spring Cloud應(yīng)用項(xiàng)目,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-05-05
  • SpringBoot如何優(yōu)雅的處理重復(fù)請(qǐng)求

    SpringBoot如何優(yōu)雅的處理重復(fù)請(qǐng)求

    對(duì)于一些用戶請(qǐng)求,在某些情況下是可能重復(fù)發(fā)送的,如果是查詢類操作并無大礙,但其中有些是涉及寫入操作的,一旦重復(fù)了,可能會(huì)導(dǎo)致很嚴(yán)重的后果,所以本文給大家介紹了SpringBoot優(yōu)雅的處理重復(fù)請(qǐng)求的方法,需要的朋友可以參考下
    2023-12-12
  • JVM類加載機(jī)制原理及用法解析

    JVM類加載機(jī)制原理及用法解析

    這篇文章主要介紹了JVM類加載機(jī)制原理及用法解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-10-10
  • Springboot 啟動(dòng)之后初始化資源的幾種方法

    Springboot 啟動(dòng)之后初始化資源的幾種方法

    在我們實(shí)際工作中,總會(huì)遇到這樣需求,在項(xiàng)目啟動(dòng)的時(shí)候需要做一些初始化的操作,比如初始化線程池,提前加載好加密證書等,本文主要介紹了Springboot 啟動(dòng)之后初始化資源的幾種方法,感興趣的可以了解一下
    2024-01-01
  • 全網(wǎng)最深分析SpringBoot MVC自動(dòng)配置失效的原因

    全網(wǎng)最深分析SpringBoot MVC自動(dòng)配置失效的原因

    這篇文章主要介紹了全網(wǎng)最深分析SpringBoot MVC自動(dòng)配置失效的原因,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • Java使用hutool實(shí)現(xiàn)文件大小的友好輸出

    Java使用hutool實(shí)現(xiàn)文件大小的友好輸出

    這篇文章主要為大家詳細(xì)介紹了Java如何使用hutool實(shí)現(xiàn)文件大小的友好輸出,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價(jià)值,感興趣的小伙伴可以了解下
    2023-11-11
  • springboot配置templates直接訪問的實(shí)現(xiàn)

    springboot配置templates直接訪問的實(shí)現(xiàn)

    這篇文章主要介紹了springboot配置templates直接訪問的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • java 中List刪除實(shí)例詳解

    java 中List刪除實(shí)例詳解

    這篇文章主要介紹了java 中List刪除實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • Window搭建部署RocketMQ步驟詳解

    Window搭建部署RocketMQ步驟詳解

    這篇文章主要介紹了Window搭建部署RocketMQ步驟詳解,RocketMq是一個(gè)由阿里巴巴開源的消息中間件,脫胎去阿里每部使用的MetaQ,在設(shè)計(jì)上借鑒了Kafka。,需要的朋友可以參考下
    2019-06-06
  • SpringBoot配置類編寫過程圖解

    SpringBoot配置類編寫過程圖解

    這篇文章主要介紹了SpringBoot配置類編寫過程圖解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-11-11

最新評(píng)論