哥哥面前一条弯弯的河 --「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()){ … }

整体参考代码:

 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。提供获取连接对象的方法,从而达到代码的重复利用。 至于如果封装工具类 那就是我们下次的内容了。。。

原文发布于微信公众号 - 程序员阿凯(AKBC159)

原文发表时间:2018-05-29

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏别先生

基于jsp+servlet图书管理系统之后台用户信息插入操作

前奏:   刚开始接触博客园写博客,就是写写平时学的基础知识,慢慢发现大神写的博客思路很清晰,知识很丰富,非常又价值,反思自己写的,顿时感觉非常low,有相当长...

2176
来自专栏一个会写诗的程序员的博客

CAS指令与MESI缓存一致性协议、 “轻量级锁” 与原子操作CAS指令与MESI缓存一致性协议、 “轻量级锁” 与原子操作

CAS指令,在Intel CPU上称为CMPXCHG。最常见的原子操作有Compare and Exchange,Self Increase/Decrease等...

1085
来自专栏程序员的知识天地

使用 JS 实现一个本地数据库

前端很多时候还是需要保存一些数据的,这里的保存指的是长久的保存。以前的思想是把数据保存在 Cookie 中,或者将 key 保存在 Cookie 中,将其他数据...

1242
来自专栏腾讯Bugly的专栏

《Android 创建线程源码与OOM分析》

| 导语 企鹅FM近几个版本的外网Crash出现很多OutOfMemory(以下简称OOM)问题,Crash的堆栈都在Thread::start方法上。该文详细...

7415
来自专栏ChaMd5安全团队

360春秋杯3道web题的简单分析

360春秋杯3道web题的简单分析 From ChaMd5安全团队核心成员 pcat&香香 where is my cat 这题一开始很坑的,存在着/.git/...

4168
来自专栏Jimoer

Java设计模式学习记录-状态模式

状态模式是一种行为模式,用于解决系统中复杂的对象状态转换以及各个状态下的封装等问题。状态模式是将一个对象的状态从该对象中分离出来,封装到专门的状态类中,使得对象...

671
来自专栏点滴积累

Fish Shell

今天看到阮一峰同学的一篇博客(Fish shell 入门教程),讲述的非常详细、清楚,有兴趣的可以直接转去查看此文,本文仅提供一下个人使用心得。 一、fish ...

3386
来自专栏lgp20151222

Vue生命周期-手动挂载理解

浏览器缓存,试了下确实一定概率可以显示,但是,哪怕浏览器不行,我们也只能从自己的代码里修改来配合它,兼容它。

601
来自专栏嵌入式程序猿

Polyspace不认识Interrupt,肿么办?

曾经在公众号中介绍过优秀的软件验证工具Polyspace,有好多猿友在交流群里咨询这个软件的问题,今天我们就典型的如何处理中断来给大家介绍下。 ...

2804
来自专栏用户画像

5.4.3微程序控制器

微程序控制器采用存储逻辑实现,也就是把微操作信号代码化,使每条机器指令转化成为一段微程序并存入一个专门的存储器(控制存储器)中。微操作控制信号由微指令产生。

651

扫码关注云+社区