哥哥面前一条弯弯的河-“JDBC”连接数据库

阅读文本大概需要 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()){ … }

整体参考代码:

是的,这里的代码很长的,‘噪声’太多了, 把业务代码全给淹没了。我们梳理一下核心业务:

指定数据库连接参数

打开数据库连接

声明SQL语句

预编译并执行SQL语句

遍历查询结果

处理每一次遍历操作

处理抛出的任何异常

处理事务

关闭数据库连接

可现在,为了正确的打开和关闭你定义的Connection,Statement,ResultSet 需要花很多功夫,再加上那些异常处理。一个 30 多行的程序, 真正做事的也就那么几行 而已。难怪有人会说我们 Java 繁琐了,这些琐碎代码真的太烦人了。

不过好在我们还可以封装工具类JDBCUtils。提供获取连接对象的方法,从而达到代码的重复利用。 至于如果封装工具类 那就是我们下次的内容了。。。

后期更多优选推文,各种资料、分享猛料放出,关注「阿凯不错」公众号,获取实时动态:

大家还有什么需求,也可以后台留言给我,公众号上还有其他学习资源哦....

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20180529G1GTKP00?refer=cp_1026
  • 腾讯「云+社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 yunjia_community@tencent.com 删除。

扫码关注云+社区

领取腾讯云代金券