0
点赞
收藏
分享

微信扫一扫

Java中JDBC详解

小时候是个乖乖 2022-04-02 阅读 71

JDBC是什么

概念:Java DataBase Connectivity

  • JDBC本质::其实是官方(sun公司)定义的一套操作所有关系型数据库的规则,即接口。 Java 访问数据库的标准规范.
  • 各个数据库厂商去实现这套接口,提供数据库驱动jar包。我们可以使用这套接口(JDBC)编程,真正执行的代码是驱动jar包中的实现类。
    在这里插入图片描述

JDBC能做什么

连接数据库

为什么有JDBC

  1. 程序员如果要开发访问数据库的程序, 只需要会调用 JDBC 接口中的方法即可, 不用关注类是如何实现的。
  2. 使用同一套 Java 代码,进行少量的修改就可以访问其他 JDBC 支持的数据库

操作步骤

	1. 导入驱动jar包 mysql-connector-java-5.1.37-bin.jar
		1.复制mysql-connector-java-5.1.37-bin.jar到项目的libs目录下
		2.右键-->Add As Library
	2. 注册驱动
	3. 获取数据库连接对象 Connection
	4. 定义sql
	5. 获取执行sql语句的对象 Statement
	6. 执行sql,接受返回结果
	7. 处理结果
	8. 释放资源
		//1. 导入驱动jar包
        //2.注册驱动
        Class.forName("com.mysql.jdbc.Driver");
        //3.获取数据库连接对象
        Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/db3", "root", "root");
        //4.定义sql语句
        String sql = "update account set balance = 500 where id = 1";
        //5.获取执行sql的对象 Statement
        Statement stmt = conn.createStatement();
        //6.执行sql
        int count = stmt.executeUpdate(sql);
        //7.处理结果
        System.out.println(count);
        //8.释放资源
        stmt.close();
        conn.close();

JDBC 的核心 API

在这里插入图片描述

DriverManager:驱动管理对象

  1. 管理和注册驱动
  2. 创建数据库的连接

类中的方法:
在这里插入图片描述
使用 JDBC 连接数据库的四个参数:
在这里插入图片描述
连接数据库的 URL 地址格式:
协议名:子协议://服务器名或 IP 地址:端口号/数据库名?参数=参数值
在这里插入图片描述
乱码的处理
如果数据库出现乱码,可以指定参数: ?characterEncoding=utf8,表示让数据库以 UTF-8 编码来处理数据。
jdbc:mysql://localhost:3306/数据库?characterEncoding=utf8

Connection 接口:

Connection 接口,具体的实现类由数据库的厂商实现,代表一个连接对象。
在这里插入图片描述

Statement 接口

在这里插入图片描述
Statement 作用:
代表一条语句对象,用于发送 SQL 语句给服务器,用于执行静态 SQL 语句并返回它所生成结果的对象。
Statement 中的方法:
在这里插入图片描述
释放资源

  1. 需要释放的对象: ResultSet 结果集, Statement 语句, Connection 连接
  2. 释放原则:先开的后关,后开的先关。 ResultSet  Statement  Connection
  3. 放在哪个代码块中: finally 块

案例

需求:确保数据库中有 3 条以上的记录,查询所有的学员信息
在这里插入图片描述

/**
* 查询所有的学生信息
*/
public class Demo6DQL {
public static void main(String[] args) throws SQLException {
		//1) 得到连接对象
		Connection connection =
		DriverManager.getConnection("jdbc:mysql://localhost:3306/day24","root","root");
		//2) 得到语句对象
		Statement statement = connection.createStatement();
		//3) 执行 SQL 语句得到结果集 ResultSet 对象
		ResultSet rs = statement.executeQuery("select * from student");
		//4) 循环遍历取出每一条记录
		while(rs.next()) {
		int id = rs.getInt("id");
		String name = rs.getString("name");
		boolean gender = rs.getBoolean("gender");
		Date birthday = rs.getDate("birthday");
		//5) 输出的控制台上
		System.out.println("编号: " + id + ", 姓名: " + name + ", 性别: " + gender + ", 生日: " +
		birthday);
	}
	//6) 释放资源
	rs.close();
	statement.close();
	connection.close();
	}
}

关于 ResultSet 接口中的注意事项:

  1. 如果光标在第一行之前,使用 rs.getXX()获取列值,报错: Before start of result set
  2. 如果光标在最后一行之后,使用 rs.getXX()获取列值,报错: After end of result set
  3. 使用完毕以后要关闭结果集 ResultSet,再关闭 Statement,再关闭 Connection

新创建一个公众号 Rockey小何同学 想相互交流的同学可以关注一下哈! 感谢支持!

举报

相关推荐

0 条评论