阅读文本大概需要 6 分钟。
1 JDBC概述
JDBC(Java Data Base Connectivity) 它是Sun公司提供的一套操作数据库的标准规范。 通过Java程序调用Sql语句对数据库进行CRUD操作。 简单地说,JDBC 可做三件事:与数据库建立连接、发送 操作数据库的语句并处理结果。
2 JDBC原理
Java 公司制定一整套 接口 数据库公司 用Java语言去实现了 接口 Java开发工程师 通过接口 和 实现类 操作数据库
JDBC的使用,就是学习 JDBC API
实现:Java -- sun 定义的一些操作接口 ,数据库厂商 提供驱动(接口的实现)
JDBC API的接口
1、DriverManager 驱动管理 (驱动 数据库公司的实现类 .jar) 2、Connection 数据库连接会话 用于获取数据库连接 3、Statement 数据通信的声明 用于执行SQL语句 PreparedStatement 预编译的声明。(提前编译,效率高,安全) 4、ResultSet 结果集 (查询到的数据集合)
3 JDBC 基本使用步骤:
// 先来介绍下操作数据库的步骤:
1、为我们的项目 添加驱动包 .jar 2、注册 加载 驱动 3、用过 DriverManager 获取数据库连接 Connection 4、准备要执行的 sql 字符串,获取数据库的会话 Statement 5、通过 Statement 执行 sql 语句 6、操作 数据库结果集 7、关闭资源
1. 四大参数准备
驱动名:com.mysql.jdbc.Driver 获取连接 Connection 需要有 数据库的地址 用户名 密码 数据库地址:jdbc:mysql://localhost:3306/exam(数据库名) URL 比较复杂
JDBC规定url的格式由三部分组成,每个部分中间使用冒号分隔。 第一部分是 jdbc,这是固定的; 第二部分是数据库名称,那么连接mysql数据库,第二部分当然是mysql了; 第三部分是由数据库厂商规定的,我们需要了解每个数据库厂商的要求, mysql的第三部分分别由数据库服务器的IP地址(localhost)、端口号(3306),以及DATABASE名称(exam) 组成。
Oracle: jdbc:oracle:thin:@主机:端口:数据库名
例如: jdbc:oracle:thin:@localhost:1521:orcl
MySQL: jdbc:mysql://主机:端口/数据库名
例如: jdbc:mysql://localhost:3306/exam
2. 注册驱动 class.forName 注册驱动用到了反射。
3. 获取链接 传入准备好的参数
Connection con=DriverManager.getConnection(url, user, password);
4. 创建statement对象 操作sql语言
Statement st=con.createStatement();
5. 创建ResultSet保存结果
String sql="select * from emp"; re=st.executeQuery(sql);
6. 遍历采用一个迭代器
while(re.next()){ … }
整体参考代码:
1 /*
2 * 1.准备四大参数
3 * 2.注册驱动Class.forName()
4 * 3.获取链接
5 * */
6 //四大参数准备
7 String classname="com.mysql.jdbc.Driver";
8 String url="jdbc:mysql://localhost:3306/exam";
9 String user="root";
10 String password="1234";
11 //注册驱动,利用到反射的原理
12 Class.forName(classname);
13 Connection con=null;
14 Statement st=null;
15 ResultSet re=null;
16 try{
17 con = DriverManager.getConnection(url, user, password);
18 //获取statement对象 操作sql语言
19 st = con.createStatement();
20 String sql="select * from emp";
21 //结果保存
22 re=st.executeQuery(sql);
23 while(re.next()){
24 String enname = re.getString(2);
25 String age = re.getString("age");
26 System.out.println(enname + ":" + age);
27 }
28 }catch(Exception e){
29 throw new RuntimeException(e);
30 }finally{
31 //关闭流
32 if(re!=null)re.close();
33 if(st!=null)st.close();
34 if(con!=null)con.close();
35 }//end finally
36 }
37 }
是的,这里的代码很长的, ‘噪声’太多了, 把业务代码全给淹没了。我们梳理一下核心业务:
指定数据库连接参数 打开数据库连接 声明SQL语句 预编译并执行SQL语句 遍历查询结果 处理每一次遍历操作 处理抛出的任何异常 处理事务 关闭数据库连接
可现在,为了正确的打开和关闭你定义的Connection,Statement,ResultSet 需要花很多功夫,再加上那些异常处理。 一个 30 多行的程序, 真正做事的也就那么几行 而已。难怪有人会说我们 Java 繁琐了,这些琐碎代码真的太烦人了。
不过好在我们还可以封装工具类 JDBCUtils。提供获取连接对象的方法,从而达到代码的重复利用。 至于如果封装工具类 那就是我们下次的内容了。。。