一文搞懂如何通过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)如果修改了配置信息,省去重新编译的过程。
使用配置文件的方式是企业开发中最常用的方式,也是各大主流框架中使用的方式。
- 点赞
- 收藏
- 关注作者
评论(0)