JDBC连接数据库
在Windows操作系统中,Java语言利用JDBC连接数据库有两种办法。一种是直接通过JDBC和数据库官方提供的支持驱动JAR包进行连接;还有一种则是用JDBC桥连接被广泛使用的ODBC,然后在ODBC中配置数据库相关信息进行连接。
什么是JDBC和ODBC?
JDBC(Java DataBase Connectivity Java数据库连接)是一种规范化的Java关系数据库API,是如今各种关系数据库应用在Java上共同遵循的约定。
ODBC(Open Database Connectivity 开放数据库连接)是为解决异构数据库间的数据共享而产生的,允许应用程序以SQL 为数据存取标准,存取不同数据库管理系统管理的数据;使应用程序直接操纵数据库中的数据,免除随数据库的改变而改变。用ODBC 可以访问各类计算机上的数据库文件。
JDBC直接连接(以连接Mysql数据库为案例,IDE为IDEA)
如上图,将mysql驱动的Jar包添加到项目环境中,然后点击Jar包,在下一层的com.mysql.jdbc包中找出驱动类文件,一般都是以Driver英文结尾的类文件。在注册不同的数据库驱动时这一点都差不多。
/*
* 注册驱动
* 在项目目录中导入mysql驱动jar包
* 这里注意Class.forName(类的全名)的语法
* */
Class.forName("com.mysql.jdbc.Driver");
因为在这里我们需要知道数据库驱动类文件的类全名,即com.mysql.jdbc.Driver。这里会报一个ClassNotFoundException异常,将代码包裹进异常处理块或者将异常抛出都可以。
注册完驱动之后,我们现在就可以跟Mysql数据库建立连接了,不过在此之前我们要先启动Mysql数据库。
通过在mysql命令行中使用show databases;我们可以查看其中数据库,这里以连接到test数据库为例。
/*
* DriverManager.getConnection(url,username,password);
* url格式:jdbc:数据库种类:分隔符:IP地址:端口号 分隔符 数据库名
* */
String url = "jdbc:mysql://localhost:3306/test";
try(Connection connection = DriverManager.getConnection(url,"root","root")){
if(connection != null){
System.out.println("数据库连接成功!");
}else{
System.out.println("数据库连接失败!");
}
}
我们将连接的声明和获取包裹在try的资源块中,这将使它在try{}块结束时自己关闭连接,实现了closeable接口的类都可以包裹进try块中达到同样的功能。
不同的数据库在url的写法上还是有小小的差别,下面我们列举几个数据库使用JDBC直接连接中url的不同。
- Oracle:url="jdbc:oracle:thin:@IP地址:端口号:数据库名或SID",example:"jdbc:oracle:thin:@localhost:1521:orcl1"。
- SQL Server 2005之后:url="jdbc:sqlserver://IP地址:端口号;DatabaseName = 数据库名",example:"jdbc:sqlserver://localhost:1433;DatabaseName = database1"。
- JavaDB(derby):url="jdbc:derby:数据库名",derby为Javajdk自带的小型数据库,只适合本机简单的项目使用,所以它的Url写法比较简单,不需要区分IP地址和端口等信息。
这里对Oracle数据库url中的thin补充说明,oracle的驱动有三中连接方式,即thin(不需要oracle客户端)、OCI(需要oracle客户端)、KPRB(由直接存储在数据库中的Java程序使用,固不需要用户名与密码也不需要url)。
JDBC-ODBC桥连接(以Access数据库为案例)
注意:从jdk1.8开始Java便不再支持JDBC-ODBC桥连接这种方式。所以jdk1.8即后续版本没有相应的驱动类文件,这是因为桥连接是能用于本地连接而且ODBC是基于Windows系统的,局限性太大。
通过上面JDBC-ODBC桥连接过程解析图可以知道,我们先将ODBC中配置好关系数据库(这里是Access)的数据源(DSN),在创建数据源的过程中我们需要关联Access数据库中我们需要使用的数据库文件。然后我们通过JDK提供的桥连接驱动使JDBC和ODBC进行桥连接,以此来达到连接目标关系数据库的目的。
下面我将详细步骤演示一遍:
我们从上述目录中找到ODBC数据源管理的程序(在控制面板的管理工具里也可以找到,但是如果使用这里面的数据源管理程序的话,有的windows系统在添加数据源时会找不到目标数据库的数据源)。
我们在系统DSN中点击右侧的添加按钮,出现安装数据源驱动界面,选择相应的数据库驱动,然后输入其中的数据源名这个数据源名就是你用JDBC-ODBC桥连接时要用到的唯一一个外部的名称。输入完数据源名称后我们就要关联数据库文件了,下图我使用Access创建了数据库文件Database12,黄色框是磁盘驱动器选择,蓝色是目录选择,红色框是文件选择,这里选中后单击确定即可。系统数据库我们不要管。
这是我们看到系统DSN中出现了我们创建的数据源。这时我们可以使用JDBC-ODBC桥连接驱动进行连接了。
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
public class FuUse{
public static void main(String[] args)throws SQLException {
try {
/*
* 注册驱动
* 这里注意Class.forName(类的全名)的语法
* */
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
/*
* DriverManager.getConnection(url);
* */
String url = "jdbc:odbc:DBAccesstest";
try(Connection connection = DriverManager.getConnection(url)){
if(connection != null){
System.out.println("数据库连接成功!");
}else{
System.out.println("数据库连接失败!");
}
}
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
}
}
查看代码,我们在写url的时候使用了数据源的名称,因为这种桥连接是通过ODBC配置好的,所以我们即不需要账户密码,也不需要IP和端口等信息。