一文搞懂如何通过JDBC连接数据库

举报
zhy1003 发表于 2021/09/16 14:17:01 2021/09/16
【摘要】 java.sql.Driver 接口是所有 JDBC 驱动程序需要实现的接口。这个接口是提供给数据库厂商使用的,不同数据库厂商提供不同的实现。

使用JDBC连接数据库,需要具备三个要素条件,分别是Driver接口实现类、URL、用户名和密码,下面分别进行介绍。

1、要素一:Driver接口实现类

Driver接口介绍:

java.sql.Driver 接口是所有 JDBC 驱动程序都需要实现的接口,这个接口是提供给数据库厂商使用的,不同数据库厂商提供不同的实现,在程序中不需要直接去访问实现了 Driver 接口的类,而是由驱动程序管理器类(java.sql.DriverManager)去调用这些Driver实现。

2、要素二:URL介绍

(1)JDBC URL 用于标识一个被注册的驱动程序,驱动程序管理器通过这个 URL 选择正确的驱动程序,从而建立到数据库的连接。

(2)JDBC URL的标准由三部分组成,各部分间用冒号分隔:

jdbc:子协议:子名称

协议:JDBC URL中的协议总是jdbc 
子协议:子协议用于标识一个数据库驱动程序
子名称:一种标识数据库的方法。子名称可以依不同的子协议而变化,用子名称的目的是为了定位数据库提供足够的信息。包含主机名(对应服务端的ip地址),端口号,数据库名。

举例如下:

jdbc:mysql://localhost:3306/test

说明:
jdbc:协议
mysql:子协议
//localhost:3306/test:子名称

(3)几种常用数据库的 JDBC URL

MySQL的连接URL编写方式:
	jdbc:mysql://主机名称:mysql服务端口号/数据库名称?参数=&参数=值
	jdbc:mysql://localhost:3306/test
	jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf8(如果JDBC程序与服务器端的字符集不一致,会导致乱码,那么可以通过参数指定服务器端的字符集)
	jdbc:mysql://localhost:3306/test?user=root&password=123456

Oracle 9i的连接URL编写方式:
	jdbc:oracle:thin:@主机名称:oracle服务端口号:数据库名称
	jdbc:oracle:thin:@localhost:1521:test

SQLServer的连接URL编写方式:
	jdbc:sqlserver://主机名称:sqlserver服务端口号:DatabaseName=数据库名称
	jdbc:sqlserver://localhost:1433:DatabaseName=test

3、要素三:用户名和密码

(1)user, password可以用“属性名=属性值”方式告诉数据库用户名和密码分别是啥。

(2)可以调用 DriverManager 类的 getConnection() 方法建立到数据库的连接。

4、使用JDBC连接数据库的五种方式

以下实践均是基于mysql8.0进行,所以使用的驱动是com.mysql.cj.jdbc.Driver,如果是mysql5.0对应驱动需要切换为com.mysql.jdbc.Driver

4.1、连接方式一

直接显式使用第三方数据库的驱动API(new com.mysql.cj.jdbc.Driver())获取数据库驱动对象。

@Test
public void testConnection1() {
    try {
        //1.提供java.sql.Driver接口实现类的对象
        Driver driver = new com.mysql.cj.jdbc.Driver();

        //2.提供url,指明具体操作的数据
        String url = "jdbc:mysql://localhost:3306/test";

        //3.提供Properties的对象,指明用户名和密码
        Properties info = new Properties();
        info.setProperty("user", "root");
        info.setProperty("password", "root");

        //4.调用driver的connect(),获取连接
        Connection conn = driver.connect(url, info);
        System.out.println(conn);
    } catch (SQLException e) {
        e.printStackTrace();
    }
}

测试结果:

4.2、连接方式二

该方式使用反射机制对Driver进行实例化,不在代码中体现第三方数据库的API,体现了面向接口编程思想,代码如下:

@Test
public void testConnection2() {
    try {
        //1.实例化Driver
        String className = "com.mysql.cj.jdbc.Driver";
        Class clazz = Class.forName(className);
        Driver driver = (Driver) clazz.newInstance();

        //2.提供url,指明具体操作的数据
        String url = "jdbc:mysql://localhost:3306/test";

        //3.提供Properties的对象,指明用户名和密码
        Properties info = new Properties();
        info.setProperty("user", "root");
        info.setProperty("password", "root");

        //4.调用driver的connect(),获取连接
        Connection conn = driver.connect(url, info);
        System.out.println(conn);
    } catch (Exception e) {
        e.printStackTrace();
    }
}

测试结果:

4.3、连接方式三

该方式使用DriverManager实现数据库的连接,测试代码如下:

@Test
public void testConnection3() {
    try {
        //1.数据库连接的4个基本要素:
        String url = "jdbc:mysql://localhost:3306/test";
        String user = "root";
        String password = "root";
        String driverName = "com.mysql.cj.jdbc.Driver";

        //2.实例化Driver
        Class clazz = Class.forName(driverName);
        Driver driver = (Driver) clazz.newInstance();
        //3.注册驱动
        DriverManager.registerDriver(driver);
        //4.获取连接
        Connection conn = DriverManager.getConnection(url, user, password);
        System.out.println(conn);
    } catch (Exception e) {
        e.printStackTrace();
    }
}

测试结果:

4.4、连接方式四

方式四其实是方式三的一个优化,在这里不必显式的注册驱动,因为在DriverManager的源码中已经存在静态代码块,实现了驱动的注册,测试代码如下:

    @Test
    public void testConnection4() {
        try {
            //1.数据库连接的4个基本要素:
            String url = "jdbc:mysql://localhost:3306/test";
            String user = "root";
            String password = "root";
            String driverName = "com.mysql.cj.jdbc.Driver";
            //2.加载驱动(①实例化Driver ②注册驱动)
            Class.forName(driverName);
            //3.获取连接
            Connection conn = DriverManager.getConnection(url, user, password);
            System.out.println(conn);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

测试结果:

4.5、连接方式五

该方式采用使用配置文件的方式来配置数据库连接的四要素信息,在工程resources目录下创建jdbc.properties文件,并录入以下内容:

user=root
password=root
url=jdbc:mysql://localhost:3306/test
driverClass=com.mysql.cj.jdbc.Driver

如下图所示:

测试代码如下:

@Test
public void testConnection5() {
    try {
        //1.加载配置文件
        InputStream is = JdbcTestDemo.class.getClassLoader().getResourceAsStream("jdbc.properties");
        Properties pros = new Properties();
        pros.load(is);

        //2.读取配置信息
        String user = pros.getProperty("user");
        String password = pros.getProperty("password");
        String url = pros.getProperty("url");
        String driverClass = pros.getProperty("driverClass");

        //3.加载驱动
        Class.forName(driverClass);

        //4.获取连接
        Connection conn = DriverManager.getConnection(url, user, password);
        System.out.println(conn);
    } catch (Exception e) {
        e.printStackTrace();
    }
}

测试结果:

使用配置文件的好处:

(1)实现了代码和数据的分离,如果需要修改配置信息,直接在配置文件中修改,不需要深入代码
(2)如果修改了配置信息,省去重新编译的过程。

使用配置文件的方式是企业开发中最常用的方式,也是各大主流框架中使用的方式。

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。