JDBC简介

  • Java数据库连接(Java Database Connectivity,JDBC),是一种用于执行SQL语句的Java API,它由一组用Java编程语言编写的类和接口组成。
  • JDBC提供了一种基准,据此可以构建更高级的工具和接口,使数据库开发人员能够编写数据库应用程序。
  • 使用JDBC编写的程序能够自动地将SQL语句传送给相应的数据库管理系统。
  • JDBC 是个"低级"接口,也就是说,它用于直接调用 SQL 命令。在这方面它的功能极佳,并比其它的数据库连接 API 易于使用,但它同时也被设计为一种基础接口,在它之上可以建立高级接口和工具。高级接口是"对用户友好的"接口,它使用的是一种更易理解和更为方便的 API,这种API在幕后被转换为诸如 JDBC 这样的低级接口。
  • JDBC扩展了Java的功能,由于Java语言本身的特点,使得JDBC具有简单、健壮、安全、可移植、获取方便等优势。

JDBC中常用类和接口

接口/类 功能说明
DriverManager 数据库驱动管理类,用于加载和卸载各种驱动程序,并建立于数据库的连接
Connection 此接口用于连接数据库
Statement 此接口用于执行SQL语句并将数据检索到ResultSet中
ResultSet 结果集接口,提供检索SQL语句返回数据的各种方法
PreparedStatement 此接口用于执行预编译的SQL语句
CallableStatement 此接口用于执行SQL存储过程的语句

JDBC开发步骤

  • 注册驱动
  • 建立连接
  • 创建statement
  • 执行sql,得到ResultSet
  • 查看结果
  • 释放资源

开发第一个JDBC程序

源码

 package com.jyroy.test;

 import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement; import com.jyroy.util.JDBCUtil; import java.sql.Connection;
import java.sql.Driver; public class MainTest { public static void main(String[] args) {
Connection connection = null;
Statement st = null;
ResultSet rs = null; try {
//1.注册驱动
DriverManager.registerDriver(new com.mysql.jdbc.Driver()); //2.建立连接
//方法一 参数一:协议+访问数据库,参数二:用户名,参数三:密码
connection = DriverManager.getConnection("jdbc:mysql://localhost/student", "root", "password"); //方法二
// DriverManager.getConnection("jdbc:msql://localhost/student?user=root&password=password"); //3.创建statement,跟数据库打交道一定需要这个对象
st = connection.createStatement(); //4.执行查询
String sql = "select * from stu";
rs = st.executeQuery(sql); //5.遍历查询每一条记录
while(rs.next()) {
int id = rs.getInt("id");
String name = rs.getString("name");
int age = rs.getInt("age"); System.out.println("id = " + id + "; name = " + name + "; age = " + age);
}
//进行资源释放
connection.close();
st.close();
rs.close(); } catch (SQLException e) {
e.printStackTrace();
}
}
}

结果

使用工具类

  借助工具类来方便JDBC的操作

获取数据库连接

  建立数据库连接的类,里面封装好实现数据库连接的函数,方便调用实现数据库连接

  这里说两个问题:

  一:

  这里多用了一个 Class.forName("com.mysql.jdbc.Driver"); 因为

  在上面的例子中,Driver这个类里面有静态代码块(java.sql.DriverManager.registerDriver(new Driver())),我们在new的时候一开始就加载了Driver类,相当于注册了两次驱动,为了避免这个情况,使用Class.forName("com.mysql.jdbc.Driver");来进行驱动的注册。

  二:

  根据JDBC官方文档,在JDBC5之后,Class.forName(); 的注册驱动,官方已经帮我们实现了,我们不加载驱动(JDBC会自动识别使mysql还是oracl什么的,当然了,如果同时用了mysql和oracl就要写上了,这个时候就没法自动确定了),直接建立连接也是可以的,大家可以自己试一下把Class.forName();这句话注释掉,也是可以完美运行的!

 package com.jyroy.DBUtil;

 import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException; public class DBUtil { private static Connection connection=null; static {
try {
//1.加载驱动程序
Class.forName("com.mysql.jdbc.Driver");
//2.获得数据库的连接
connection = DriverManager.getConnection("jdbc:mysql://localhost/student", "root", "password"); } catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
}
}
//将获得的数据库与java的链接返回(返回的类型为Connection)
public static Connection getConnection(){
return connection;
}
}

  我们在MainTest中调用

 connection = DBUtil.getConnection();

  运行之后,同样可以得到相同的查询结果

进行资源释放

  上面的资源释放,只是简单的close掉了,更好的办法释放资源还是在finally语句块中,因此重新编写代码,使用finally语句块,我这里直接写了一个工具类,让代码更清晰一点。

    finally一般拿来做一些善后清理工作,当try块里出现错误的话,会立即跳出try块,找到匹配的错误,执行catch块里的语句,此时,可能在try块里打开的文件没关闭,连接的网络没断开,对这些浪费的内存就不能及时释放回收,因此利用finally进行一些善后工作
 package com.jyroy.util;

 import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement; public class JDBCUtil {
/*
释放资源
*/ public static void release(Connection connection, Statement st, ResultSet rs) {
closeConn(connection);
closeRs(rs);
closeSt(st);
} private static void closeRs(ResultSet rs) {
try {
if(rs!=null) {
rs.close();
}
} catch (SQLException e) {
e.printStackTrace();
}finally {
rs = null;
}
} private static void closeSt(Statement st) {
try {
if(st!=null) {
st.close();
}
} catch (SQLException e) {
e.printStackTrace();
}finally {
st = null;
}
} private static void closeConn(Connection connection) {
try {
if(connection!=null) {
connection.close();
}
} catch (SQLException e) {
e.printStackTrace();
}finally {
connection = null;
}
} }

  在MainTest类中进行使用

 JDBCUtil.release(connection, st, rs);

数据库的增删查改

查询

 package com.jyroy.test;

 import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement; import com.jyroy.DBUtil.DBUtil;
import com.jyroy.util.JDBCUtil; import java.sql.Connection;
import java.sql.Driver; public class MainTest { public static void main(String[] args) { Connection conn = null;
Statement st = null;
ResultSet rs = null; try {
//1.获取连接对象
conn = DBUtil.getConnection(); //2.根据连接对象,得到statement
st = conn.createStatement(); //3.执行查询
String sql = "select * from stu";
rs = st.executeQuery(sql); //4.遍历输出结果
while(rs.next()) {
String name = rs.getString("name");
int age = rs.getInt("age"); System.out.println(name + " " + age);
} } catch (SQLException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
}finally {
JDBCUtil.release(conn, st, rs);
}
}
}

插入

 @Test
public void testInsert() {
Connection conn = null;
Statement st = null; try {
//1.获取连接对象
conn = DBUtil.getConnection(); //2.根据连接对象,得到statement
st = conn.createStatement(); //3.执行插入
String sql = "insert into stu values(null, 'xiaoming', 12)"; int result = st.executeUpdate(sql); //result表示影响的行数,大于0表示添加成功,否则失败
if(result > 0) {
System.out.println("添加成功");
}
else {
System.out.println("添加失败");
} } catch (SQLException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
}finally {
JDBCUtil.release(conn, st);
}
}

删除

 @Test
public void testDelete() {
Connection conn = null;
Statement st = null; try {
//1.获取连接对象
conn = DBUtil.getConnection(); //2.根据连接对象,得到statement
st = conn.createStatement(); //3.执行删除
String sql = "delete from stu where name = 'xiaoming'"; int result = st.executeUpdate(sql); //result表示影响的行数,大于0表示添加成功,否则失败
if(result > 0) {
System.out.println("删除成功");
}
else {
System.out.println("删除失败");
} } catch (SQLException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
}finally {
JDBCUtil.release(conn, st);
}
}

更新

 @Test
public void testUpdate() {
Connection conn = null;
Statement st = null; try {
//1.获取连接对象
conn = DBUtil.getConnection(); //2.根据连接对象,得到statement
st = conn.createStatement(); //3.执行更新
String sql = "update stu set age = 11 where name = 'zhangsan'"; int result = st.executeUpdate(sql); //result表示影响的行数,大于0表示添加成功,否则失败
if(result > 0) {
System.out.println("更新成功");
}
else {
System.out.println("更新失败");
} } catch (SQLException e) {
// TODO 自动生成的 catch 块
e.printStackTrace();
}finally {
JDBCUtil.release(conn, st);
}
}

使用JDBC连接操作数据库的更多相关文章

  1. JAVA采用JDBC连接操作数据库详解

    JDBC连接数据库概述 一.JDBC基础知识 JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供 ...

  2. JDBC连接-操作数据库

    JDBC连接数据库的操作步骤 *条件:先启动mysql,然后创建新连接.这里我用Navicat工具来操作数据库. 前面是创建数据库,以及授权的问题.然后打开eclipse 这里我整理一下 抛出的两个异 ...

  3. java jdbc 连接mysql数据库 实现增删改查

    好久没有写博文了,写个简单的东西热热身,分享给大家. jdbc相信大家都不陌生,只要是个搞java的,最初接触j2ee的时候都是要学习这么个东西的,谁叫程序得和数据库打交道呢!而jdbc就是和数据库打 ...

  4. jdbc连接oracle数据库

    /*** 通过改变配置文件来连接不同数据库*/package com.xykj.jdbc; import static org.junit.Assert.*; import java.io.Input ...

  5. Crystal Reports 2008(水晶报表) JDBC连接mysql数据库

    在本blog中,主要介绍的是Crystal Reports 2008使用JDBC连接mysql数据库. 在连接之间,首先要确认你电脑上面都安装了mysql数据库. 其次,就是jdbc连接数据时候所使用 ...

  6. JDBC连接Oracle数据库的问题

    场景:最近做一个java web项目,使用jdbc连接Oracle数据库,遇到了两个问题. 问题1:jdbc连接不上Ubuntu Oracle服务器? 后来发现这个问题的原因是由于连接字符串写错了,修 ...

  7. JDBC连接MySQL数据库及演示样例

    JDBC是Sun公司制定的一个能够用Java语言连接数据库的技术. 一.JDBC基础知识         JDBC(Java Data Base Connectivity,java数据库连接)是一种用 ...

  8. JDBC连接MySQL数据库及示例

      JDBC是Sun公司制定的一个可以用Java语言连接数据库的技术. 一.JDBC基础知识         JDBC(Java Data Base Connectivity,java数据库连接)是一 ...

  9. JDBC 连接mysql数据库

    JDBC 连接mysql数据库jar包:mysql-connector-java-5.1.47.jar 下载:mysql-connector-java-5.1.47.jar jdbc:java dat ...

随机推荐

  1. 电脑开机出现“致命错误C0000034。。。”--该怎么办?

    win7或win8系统的电脑在开机时出现了 "致命错误C0000034 正在更新操作236,共156764个0000000000000000.cdf-ms "的提示并不能正常启动系 ...

  2. java中的数组二分法

    数组二分法意在以较快的速度查找到某个值的下标位置. 二分法的核心思想:找到一个数组的中间位置值,判断某个数值是在这个中间值的左边还是右边,如果是左边,将中间位置之前进行二分,二分后,结束位置变为原始中 ...

  3. 前端随笔 - JavaScript中的闭包

    前阵子重新复习了一下js基础知识,第一篇博客就以分享闭包心得为开始吧. 首先,要理解闭包,就必须要了解一个概念:作用域链. 作用域链 作用域代表着可访问变量的集合,变量分为全局变量和局部变量两种,在函 ...

  4. 响应式WEB设计的基本原则大总结

    响 应式Web设计对于解决多类型屏幕问题来说是个不错方案,但从印刷的角度来看,其却存在着很多的困难.没有固定的页面尺寸.没有毫米或英寸,没有任何物理 限制,让人感到无从下手.随着建立网站可用的各种小工 ...

  5. Jenkins 集成 SonarQube Scanner

    1.   安装Jenkins 下载安装包,这里我们下载war包 https://jenkins.io/download/ 运行jenkins.war的方式有两种: 第一种:将其放到tomcat中运行( ...

  6. SpringBoot从零单排 ------ 拦截器的使用

    在项目开发中我们常常需要对请求进行验证,如登录校验.权限验证.防止重复提交等等,通过拦截器来过滤请求.自定义一个拦截器需要实现HandlerInterceptor接口.代码如下: import org ...

  7. Java进阶篇设计模式之九----- 解释器模式和迭代器模式

    前言 在上一篇中我们学习了行为型模式的责任链模式(Chain of Responsibility Pattern)和命令模式(Command Pattern).本篇则来学习下行为型模式的两个模式, 解 ...

  8. Redis的正确使用姿势

    前言 说到分布式缓存,可能大多数人脑海浮现的就是redis了,为什么redis能够在竞争激烈的缓存大战中脱颖而出呢?原因无非有一下几点:性能好,丰富的特性跟数据结构,api操作简单.但是用的人多了,就 ...

  9. netcore编程之后面对不习惯的xshell黑屏部署,是时候使用jenkins自动化发布工具了

     在很久之前net还只能在windows上部署的时候,或许很多创业公司的朋友发布项目还都是人肉部署,反正windows都是可视化的界面,拖拖拉拉,开开关关还不 是特别麻烦...现如今你的项目需要在li ...

  10. linux文件权限总结(创建root不可以删除文件、只可追加的日志文件等)

    文件类型 对于文件和目录的访问权力是根据读访问,写访问,和执行访问来定义的. 我们来看一下 ls 命令的输出结果 [root@iZ28dr6w0qvZ test]# ls -l 总用量 72 -rw- ...