小迷糊与JDBC的初相逢

JDBC概述

客户端操作服务器的方式

  • 方式一:使用第三方客户端来访问mysql。
  • 方式二:使用命令行进行访问
  • 使用java程序来访问mysql数据库

什么是JDBC?

JDBC(Java Data Base Connectivity) 是 Java 访问数据库的标准规范.是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用Java语言编写的类和接口组成。是Java访问数据库的标准规范。

JDBC原理(由驱动实现)

JDBC是接口,**驱动是接口的实现,**没有驱动将无法完成数据库连接,从而不能操作数据库!每个数据库厂商都需要提供自己的驱动,用来连接自己公司的数据库,也就是说驱动一般都由数据库生成厂商提供。具体可见下图。JDBC与各个数据之间的关系/JDBC的原理
**JDBC就是由sun公司定义的一套操作所有关系型数据库的规则(接口),**而数据库厂商需要实现这套接口,提供数据库驱动jar包, 我们可以使用这套接口编程,真正执行的代码是对应驱动包中的实现类。
重点:JDBC就是一套接口,要是用就要调用对应的驱动jar包。

JDBC开发

准备一组数据

-- 创建 jdbc_user表
CREATE TABLE jdbc_user (
id INT PRIMARY KEY AUTO_INCREMENT ,
username VARCHAR(50),
PASSWORD VARCHAR(50),
birthday DATE
);
-- 添加数据
INSERT INTO jdbc_user (username, PASSWORD,birthday)
VALUES('admin1', '123','1991/12/24'),
('admin2','123','1995/12/24'),
('test1', '123','1998/12/24'),
('test2', '123','2000/12/24');

MySql驱动包

驱动的添加步骤

  • 将MySQL驱动包添加到jar包库文件夹中,Myjar文件夹,用于存放当前项目需要的所有jar包。
  • 在 idea中 配置jar包库的位置添加数据库驱动包
  • . 创建一个新的项目jdbc_task01, 配置jar包库
    在这里插入图片描述

API使用:

注册驱动
  • JDBC规范定义驱动接口: java…sql.Driver
  • MySql驱动包提供了实现类: com.mysql.jdbc.Driver
  • 案例:
public class JDBCDemo01 {
   
public static void main(String[] args) throws ClassNotFoundException {
   
//1.注册驱动
// forName 方法执行将类进行初始化
Class.forName("com.mysql.jdbc.Driver");
}
}

原理:静态代码块,随着类的加载而加载
Class类的forName方法 ,可以将一个类初始化, 现在我们一起Driver类的 看一下源码

/
/ Driver类是MySql提供的数据库驱动类, 实现了JDBC的Driver接口 java.sql.Driver
public class Driver extends NonRegisteringDriver implements java.sql.Driver {
   
// 空参构造
public Driver() throws SQLException {
   
} /
/静态代码块,Class类的 forName()方法将Driver类 加载到内存, static代码块会自动执行
static {
   
try {
   
/*
DriverManager 驱动管理类
registerDriver(new Driver) 注册驱动的方法
注册数据库驱动
*/
DriverManager.registerDriver(new Driver());
} catch (SQLException var1) {
   
throw new RuntimeException("Can't register driver!");
		}
	}
}

注意:
从 JDBC3 开始,目前已经普遍使用的版本。可以不用注册驱动而直接使用。Class.forName 这句话可以省略。

获取连接
  • Connection 接口,代表一个连接对象 ,具体的实现类由数据库的厂商实现
  • 使用 DriverManager类的静态方法, getConnection可以获取数据库的连接。
  • 获取连接的静态方法 说明
    Connection getConnection(String url, String user,
    String password)
    通过连接字符串和用户名,密码来获取数据
    库连接对象
    1)连接参数说明
    JDBC获取连接参数说明
    2)url详解
    jdbc:mysql://localhost:3306/db4?characterEncoding=UTF-8
    JDBC规定url的格式由三部分组成,每个部分中间使用冒号分隔
    • 第一部分是协议 jdbc,这是固定的;
    • 第二部分是子协议,就是数据库名称,连接mysql数据库,第二部分当然是mysql了;
    • 第三部分是由数据库厂商规定的,我们需要了解每个数据库厂商的要求,mysql的第三部分分别由数据库服务器的IP地址(localhost)、端口号(3306),以及要使用的 数据库名称 组成。
      3)案例:
public class JDBCDemo02 {
   
public static void main(String[] args) throws Exception {
   
//1.注册驱动
Class.forName("com.mysql.jdbc.Driver");
//2.获取连接 url,用户名, 密码
String url = "jdbc:mysql://localhost:3306/db4";
Connection con = DriverManager.getConnection(url, "root", "123456");
//com.mysql.jdbc.JDBC4Connection@2e3fc542
System.out.println(con);
}
}
获取语句执行对象
  • 通过Connection 的 createStatement方法 获取sql语句执行对象
    Connection接口中的方法
    Statement createStatement() 创建 SQL语句执行对象
  • Statement : 代表一条语句对象,用于发送 SQL 语句给服务器,用于执行静态 SQL 语句并返回它所生成结
    果的对象。常用的方法有:
    1)int executeUpdate(String sql); 执行insert update delete语句. 返回int类型,代表受影响的行数

2)ResultSet executeQuery(String
sql); 执行select语句, 返回ResultSet结果集对象

案例1:

处理结果集
  • 只有在进行查询操作的时候, 才会处理结果集
  • 案例:
p
ublic class JDBCDemo04 {
   
public static void main(String[] args) throws SQLException {
   
//1.注册驱动 可以省略
//2.获取连接
String url = "jdbc:mysql://localhost:3306/db4";
Connection con = DriverManager.getConnection(url, "root", "123456");
//3.获取 Statement对象
Statement statement = con.createStatement();
String sql = "select * from jdbc_user";
//执行查询操作,返回的是一个 ResultSet 结果对象
ResultSet resultSet = statement.executeQuery(sql);
//4.处理结果集 resultSet
}
}
  • ResultSet接口
    作用:封装数据库查询的结果集,对结果集进行遍历,取出每一条记录。
    ResultSet接口方法 说明
    • boolean next()
    1. 游标向下一行
    2. 返回 boolean 类型,如果还有下一条记录,返回true,否则返回 false
    • xxx getXxx( String or int)
    1. 通过列名,参数是 String 类型。返回不同的类型
    2. 通过列号,参数是整数,从 1 开始。返回不同的类
      结果集重载方法可以是String/int
      案例:
public class Demo04 {
   
        public static void main(String[] args) throws SQLException, SQLException {
   
//1.注册驱动 可以省略
//2.获取连接
            String url = "jdbc:mysql://localhost:3306/db4";
            Connection con = DriverManager.getConnection(url, "root", "123456");
//3.获取 Statement对象
            Statement statement = con.createStatement();
            String sql = "select * from jdbc_user";
//执行查询操作,返回的是一个 ResultSet 结果对象
            ResultSet r
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值