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

Java實現數據庫連接的最詳細教程分享

 更新時間:2023年05月21日 08:27:29   作者:無聲編碼器  
JDBC,Java?Database?Connectivity,即Java數據庫連接,是?Java?中的一套和數據庫進行交互的API,本文就來講講Java如何利用JDBC實現數據庫的連接吧

JDBC,Java Database Connectivity,即 Java 數據庫連接。實際上 JDBC 是 Java 中的一套和數據庫進行交互的API。

因為 Java 程序員需要連接多種數據庫,為了避免每一個數據庫都學習一套新的API,SUN公司提出一個JDBC接口,各個數據庫廠商根據接口寫實現類(驅動),這樣 Java 程序員只需要掌握 JDBC 接口中的一套方法,就可以訪問任何數據庫。

使用 JDBC 可以創(chuàng)建一個 Maven 工程,使用 Maven 工具便捷的下載 MySQL 驅動相關 Jar 包。使用實例如下:

1.創(chuàng)建 Maven 工程

使用 IntelliJ IDEA 新建工程,選擇 Maven 工程:

設置項目名稱:

2.添加 MySQL 驅動依賴 Jar 包

在 Maven 工程的 pom.xml 文件中加入 MySQL 驅動依賴,并下載 Jar 包:

3.創(chuàng)建一個測試使用的 MySQL 數據庫

// 創(chuàng)建名為 test_base 的數據庫
CREATE DATABASE test_base;
// 使用 test_base 數據庫
USE test_base;
// 創(chuàng)建名為 websites 的表
CREATE TABLE `websites` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` char(20) NOT NULL DEFAULT '' COMMENT '站點名稱',
  `url` varchar(255) NOT NULL DEFAULT '',
  `alexa` int(11) NOT NULL DEFAULT '0' COMMENT 'Alexa 排名',
  `country` char(10) NOT NULL DEFAULT '' COMMENT '國家',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=10 DEFAULT CHARSET=utf8;
// 在 websites 中插入數據
INSERT INTO `websites` VALUES ('1', 'Google', 'https://www.google.cm/', '1', 'USA'), 
('2', '淘寶', 'https://www.taobao.com/', '13', 'CN'), 
('3', '菜鳥教程', 'http://www.runoob.com', '5892', ''), 
('4', '微博', 'http://weibo.com/', '20', 'CN'), 
('5', 'Facebook', 'https://www.facebook.com/', '3', 'USA'),
('6', 'JueJin', 'https://www.juejin.cn/', '2213', 'CN');

4.創(chuàng)建 Java 文件,編寫 JDBC 相關代碼

import java.sql.*;
/**
 * @Author:WG
 * @Package:PACKAGE_NAME
 * @Project:JDBCTest
 * @name:MySQLDemo
 * @Date:2023/5/17 21:35
 * @Filename:MySQLDemo
 */
public class MySQLDemo {
    // MySQL 8.0 以下版本 - JDBC 驅動名及數據庫 URL
    static final String JDBC_DRIVER = "com.mysql.jdbc.Driver";
    static final String DB_URL = "jdbc:mysql://localhost:3306/test_base?useSSL=false&allowPublicKeyRetrieval=true&serverTimezone=UTC";
    // MySQL 8.0 以上版本 - JDBC 驅動名及數據庫 URL
    //static final String JDBC_DRIVER = "com.mysql.cj.jdbc.Driver";
    //static final String DB_URL = "jdbc:mysql://localhost:3306/test_base?useSSL=false&allowPublicKeyRetrieval=true&serverTimezone=UTC";
    // 數據庫的用戶名與密碼,需要根據自己的設置
    static final String USER = "root";
    static final String PASS = "root";
    public static void main(String[] args) {
        Connection conn = null;
        Statement stmt = null;
        try{
            // 注冊 JDBC 驅動
            Class.forName(JDBC_DRIVER);
            System.out.println("連接數據庫...");
            // 獲取連接對象
            conn = DriverManager.getConnection(DB_URL,USER,PASS);
            System.out.println(" 實例化Statement對象...");
            // 創(chuàng)建 Sql 執(zhí)行對象
            stmt = conn.createStatement();
            // Sql 查詢語句
            String sql = "SELECT id, name, url FROM websites";
            // 執(zhí)行 Sql
            ResultSet rs = stmt.executeQuery(sql);
            // 展開結果集數據庫,next()會判斷有無下條數據,有的話返回 true
            while(rs.next()){
                // 通過字段檢索
                int id  = rs.getInt("id");
                String name = rs.getString("name");
                String url = rs.getString("url");
                // 輸出數據
                System.out.print("ID: " + id);
                System.out.print(", 站點名稱: " + name);
                System.out.print(", 站點 URL: " + url);
                System.out.print("\n");
            }
            // 完成后關閉
            rs.close();
            stmt.close();
            conn.close();
        }catch(SQLException se){
            // 處理 JDBC 錯誤
            se.printStackTrace();
        }catch(Exception e){
            // 處理 Class.forName 錯誤
            e.printStackTrace();
        }finally{
            try{
                // 關閉資源
                if(stmt!=null) stmt.close();
            }catch(SQLException se2){
                // 什么都不做
            }
            try{
                if(conn!=null) conn.close();
            }catch(SQLException se){
                se.printStackTrace();
            }
        }
        System.out.println("Goodbye!");
    }
}
// 程序運行結果如下:
// 連接數據庫...
// 實例化Statement對象...
// ID: 1, 站點名稱: Google, 站點 URL: https://www.google.cm/
// ID: 2, 站點名稱: 淘寶, 站點 URL: https://www.taobao.com/
// ID: 3, 站點名稱: 菜鳥教程, 站點 URL: http://www.runoob.com
// ID: 4, 站點名稱: 微博, 站點 URL: http://weibo.com/
// ID: 5, 站點名稱: Facebook, 站點 URL: https://www.facebook.com/
// ID: 6, 站點名稱: JueJin, 站點 URL: https://www.juejin.cn/
// Goodbye!

DBCP - 數據庫連接池

數據庫連接池可以預先設置一定數量的初始連接,如果有業(yè)務需要使用連接,則從連接池中直接獲取,如果連接池中連接用光,這些連接請求將被加入到等待隊列中,等待連接歸還后再獲取連接。

數據庫連接池避免了每一次業(yè)務都需要和數據庫服務器建立一次連接,業(yè)務處理完成后再斷開連接,因為頻繁的開關連接非常的浪費資源,甚至造成服務器崩潰。

DBCP 使用實例

1.使用數據庫連接池需要在 Maven 工程的 pom.xml 文件中加入依賴,并下載 Jar 包:

 <!-- dependencies標簽主要用于管理項目中需要引入的其他依賴 -->
    <dependencies>
        <!--mysql驅動-->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.39</version>
        </dependency>
        <!--數據庫連接池-->
        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-dbcp2</artifactId>
            <version>2.1.1</version>
        </dependency>
    </dependencies>

2.創(chuàng)建 Java 文件,編寫 JDBC 相關代碼:

import org.apache.commons.dbcp2.BasicDataSource;
import java.sql.*;
/**
 * @Author:WG
 * @Package:PACKAGE_NAME
 * @Project:JDBCTest
 * @name:DBCPDemo
 * @Date:2023/5/18 15:09
 * @Filename:DBCPDemo
 */
public class DBCPDemo {
    public static void main(String[] args) {
        Connection conn = null;
        Statement stmt = null;
        // 獲取連接池
        BasicDataSource dataSource = JdbcUtils.getDataSource();
        try {
            // 在連接池中獲取連接
            conn = dataSource.getConnection();
            // 創(chuàng)建 Sql 執(zhí)行對象
            stmt = conn.createStatement();
            // Sql 查詢語句
            String sql = "SELECT id, name, url FROM websites";
            // 執(zhí)行 Sql
            ResultSet rs = stmt.executeQuery(sql);
            // 展開結果集數據庫,next()會判斷有無下條數據,有的話返回 true
            while(rs.next()){
                // 通過字段檢索
                int id  = rs.getInt("id");
                String name = rs.getString("name");
                String url = rs.getString("url");
                // 輸出數據
                System.out.print("ID: " + id);
                System.out.print(", 站點名稱: " + name);
                System.out.print(", 站點 URL: " + url);
                System.out.print("\n");
            }
            // 完成后關閉
            rs.close();
            stmt.close();
            conn.close();
        } catch (SQLException se) {
            // 獲取連接錯誤
            se.printStackTrace();
        }finally{
            try{
                // 關閉資源
                if(stmt!=null) stmt.close();
            }catch(SQLException se2){
                // 什么都不做
            }
            try{
                if(conn!=null) conn.close();
            }catch(SQLException se){
                se.printStackTrace();
            }
        }
        System.out.println("Goodbye!");
    }
}
class JdbcUtils {
    // 創(chuàng)建連接池
    private static BasicDataSource dataSource = new BasicDataSource();
    static {
        //必須要的配置
        dataSource.setDriverClassName("com.mysql.jdbc.Driver");
        dataSource.setUrl("jdbc:mysql://localhost:3306/test_base?useSSL=false&allowPublicKeyRetrieval=true&serverTimezone=UTC");
        dataSource.setUsername("root");
        dataSource.setPassword("root");
        //可選配置
        dataSource.setMaxTotal(10);//連接池最大連接數
        dataSource.setMaxIdle(5);//連接池最大空閑數
        dataSource.setMinIdle(3);//連接池最小空閑數
        dataSource.setInitialSize(10);//初始化連接池時的連接數
    }
    // 獲取連接池
    public static BasicDataSource getDataSource() {
        return dataSource;
    }
}
// 程序運行結果如下:
// ID: 1, 站點名稱: Google, 站點 URL: https://www.google.cm/
// ID: 2, 站點名稱: 淘寶, 站點 URL: https://www.taobao.com/
// ID: 3, 站點名稱: 菜鳥教程, 站點 URL: http://www.runoob.com
// ID: 4, 站點名稱: 微博, 站點 URL: http://weibo.com/
// ID: 5, 站點名稱: Facebook, 站點 URL: https://www.facebook.com/
// ID: 6, 站點名稱: JueJin, 站點 URL: https://www.juejin.cn/
// Goodbye!

使用數據庫連接池也同樣連接到了 MySQL 數據庫,并打印了查詢數據,這里并沒有看出使用數據庫連接池有什么優(yōu)勢,但如果使用 JDBC(非數據庫連接池方式) 與 DBCP (數據庫連接池方式)同時進行20000次數據庫連接查詢,消耗時間大概如下:

JDBC 耗時 40898毫秒
DBCP 耗時 3726毫秒

以上就是Java實現數據庫連接的最詳細教程分享的詳細內容,更多關于Java數據庫連接的資料請關注腳本之家其它相關文章!

相關文章

  • SpringBoot集成JPA持久層框架,簡化數據庫操作

    SpringBoot集成JPA持久層框架,簡化數據庫操作

    JPA(Java Persistence API)意即Java持久化API,是Sun官方在JDK5.0后提出的Java持久化規(guī)范。主要是為了簡化持久層開發(fā)以及整合ORM技術,結束Hibernate、TopLink、JDO等ORM框架各自為營的局面。JPA是在吸收現有ORM框架的基礎上發(fā)展而來,易于使用,伸縮性強。
    2021-06-06
  • idea新建文件后文件夾消失的問題及解決

    idea新建文件后文件夾消失的問題及解決

    這篇文章主要介紹了idea新建文件后文件夾消失的問題及解決,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • SpringBoot去除參數前后空格和XSS過濾

    SpringBoot去除參數前后空格和XSS過濾

    本文主要介紹了SpringBoot去除參數前后空格和XSS過濾,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • SpringAop切入點execution表達式的深入講解

    SpringAop切入點execution表達式的深入講解

    Spring AOP 可能會經常使用 execution切入點指示符,下面這篇文章主要給大家介紹了關于SpringAop切入點execution表達式的相關資料,需要的朋友可以參考下
    2021-08-08
  • java字符串替換排序實例

    java字符串替換排序實例

    這篇文章主要介紹了java字符串替換排序實例,有需要的朋友可以參考一下
    2014-01-01
  • springboot自定義攔截器簡單使用及舉例

    springboot自定義攔截器簡單使用及舉例

    Spring Boot攔截器是AOP的一種實現,專門攔截對控制層的請求,主要應用于判斷用戶權限,攔截webSocket請求,下面這篇文章主要給大家介紹了關于springboot自定義攔截器簡單使用及舉例的相關資料,需要的朋友可以參考下
    2023-01-01
  • Java中的弗洛伊德(Floyd)算法

    Java中的弗洛伊德(Floyd)算法

    這篇文章主要介紹了Java中的弗洛伊德(Floyd)算法,Floyd算法又稱為插點法,是一種利用動態(tài)規(guī)劃的思想尋找給定的加權圖中多源點之間最短路徑的算法,與Dijkstra算法類似,需要的朋友可以參考下
    2024-01-01
  • Java集合定義與用法實例總結【Set、List與Map】

    Java集合定義與用法實例總結【Set、List與Map】

    這篇文章主要介紹了Java集合定義與用法,結合實例形式總結分析了Java集合中Set、List和Map相關概念、功能、用法及操作注意事項,需要的朋友可以參考下
    2018-08-08
  • @RequestBody的使用詳解

    @RequestBody的使用詳解

    這篇文章主要介紹了@RequestBody的使用詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-12-12
  • 解決IDEA報錯java無效的目標發(fā)行版:22

    解決IDEA報錯java無效的目標發(fā)行版:22

    在使用IDEA編譯項目時,可能會遇到JDK版本不一致的錯誤,這篇文章主要介紹了解決IDEA報錯java無效的目標發(fā)行版:22的相關資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2024-10-10

最新評論