• MYSQL 之 JDBC(二): 数据库连接(二)通过DriverManager获取数据库连接


    通过DriverManager获取数据库连接

    修改一下配置文件

    driver=com.mysql.cj.jdbc.Driver
    jdbcUrl=jdbc:mysql://localhost:3306/testjdbc?serverTimezone=GMT%2B8
    user=root
    password=123456
    • 代码(我觉得废话有点多,同一个知识点翻来覆去的讲,并且有的疑点还没解决)

    • 比如说:利用Driver和DriverManager都能用不同的数据库,为什么DriverManager更好

    package com.litian.jdbc;
    
    import java.io.InputStream;
    import java.sql.Connection;
    import java.sql.Driver;
    import java.sql.DriverManager;
    import java.sql.SQLException;
    import java.util.Properties;
    
    
    /**
     * @author: Li Tian
     * @contact: litian_cup@163.com
     * @software: IntelliJ IDEA
     * @file: JDBCTest.java
     * @time: 2019/12/15 18:56
     * @desc: JDBC试验,Driver是一个接口:数据库厂商必须提供实现的接口,能从其中获取数据库连接。
     */
    
    public class JDBCTest {
    
        public Connection getConnection2() throws Exception {
            // 1. 准备连接数据库的4个字符串。
            // 1.1 创建Properties对象
            Properties properties = new Properties();
            // 1.2 获取jdbc.properties对应的输入流
            InputStream in = this.getClass().getClassLoader().getResourceAsStream("jdbc.properties");
            // 1.3 加载1.2对应的输入流
            properties.load(in);
            // 1.4 具体决定user,password等4个字符串。
            String user = properties.getProperty("user");
            String password = properties.getProperty("password");
            String jdbcUrl = properties.getProperty("jdbcUrl");
            String driver = properties.getProperty("driver");
            // 2. 加载数据库驱动程序
            Class.forName(driver);
            // 3. 通过DriverManager的getConnection()方法获取数据库连接。
            return DriverManager.getConnection(jdbcUrl, user, password);
        }
    
        /**
         * DriverManager是驱动的管理类
         * 1. 可以通过重载的getConnection()方法获取数据库连接。较为方便
         * 2. 可以同时管理多个驱动程序:若注册了多个数据库连接,则调动getConnection()方法时
         *    传入的参数不同,则返回不同的数据库连接
         */
        public void testDriverManager() throws Exception {
            // 1. 准备连接数据库的4个字符串
    
            // 驱动的全类名
            String driverClass = null;
            String jdbcUrl = null;
            String user = null;
            String password = null;
    
            // 读取类路径下的jdbc.propertites 文件
            InputStream in = getClass().getClassLoader().getResourceAsStream("jdbc.properties");
            Properties properties = new Properties();
            properties.load(in);
            driverClass = properties.getProperty("driver");
            jdbcUrl = properties.getProperty("jdbcUrl");
            user = properties.getProperty("user");
            password = properties.getProperty("password");
    
            // 2. 加载数据库驱动程序(对应的Driver实现类中有注册驱动的静态代码块程序)
            // 下面的注册程序已经写好了,不需要自己写
            // DriverManager.registerDriver((Driver) Class.forName(driverClass).newInstance());
            Class.forName(driverClass);
    
            // 3. 通过DriverManager的getConnection()方法获取数据库连接
            Connection connection = DriverManager.getConnection(jdbcUrl, user, password);
            System.out.println(connection);
    
        }
    
        public void test1() throws SQLException {
            // 1. 创建一个Driver实现类的对象
            Driver driver = new com.mysql.jdbc.Driver();
            // 2. 准备连接数据库的基本信息:url,user,password
            String url = "jdbc:mysql://localhost:3306/girls";
            Properties info = new Properties();
            info.put("user", "root");
            info.put("password", "tian19951103");
    
            // 3. 调用Driver接口的connect(url, info)获取数据库连接
            Connection connection = driver.connect(url, info);
            System.out.println(connection);
        }
    
        // 编写一个通用的方法,在不修改源程序的情况下,可以获取任何数据库的连接
        public Connection getConnection() throws Exception {
            String driverClass = null;
            String jdbcUrl = null;
            String user = null;
            String password = null;
    
            // 读取类路径下的jdbc.propertites 文件
            InputStream in = getClass().getClassLoader().getResourceAsStream("jdbc.properties");
            Properties properties = new Properties();
            properties.load(in);
            driverClass = properties.getProperty("driver");
            jdbcUrl = properties.getProperty("jdbcUrl");
            user = properties.getProperty("user");
            password = properties.getProperty("password");
    
            Driver driver = (Driver) Class.forName(driverClass).newInstance();
    
            Properties info = new Properties();
            info.put("user", user);
            info.put("password", password);
            Connection connection = driver.connect(jdbcUrl, info);
    
            return connection;
        }
    
        public void testGetConnection() throws Exception {
            System.out.println(getConnection());
        }
    
        public static void main(String[] args) throws Exception {
            // new JDBCTest().testGetConnection();
            // new JDBCTest().testDriverManager();
            Connection conn = new JDBCTest().getConnection2();
            System.out.println(conn);
        }
    }

    ————————————————
    版权声明:本文为CSDN博主「李英俊小朋友」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    原文链接:https://blog.csdn.net/qq_21579045/article/details/105386353

  • 相关阅读:
    201671010439-词频统计软件项目报告
    201671010439温永琴 实验三作业互评与改进
    读构建之法提出的问题
    实验十四 团队项目评审&课程学习总结
    201671010441 徐浩杰 实验四 附加实验 项目互评
    201671010441 徐浩杰《英文文本统计分析》结对项目报告
    201671010441徐浩杰 词频统计软件项目报告
    201671010441 徐浩杰 实验三作业互评与改进报告
    实验一 通读教材后提问
    实验十四 团队项目评审&课程学习总结
  • 原文地址:https://www.cnblogs.com/qiu-hua/p/13199442.html
Copyright © 2020-2023  润新知