JDBC详解

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: Java Database Connectivity(JDBC)是Java语言中用于访问关系型数据库的标准接口,定义了一组API,使Java程序能以统一方式连接、访问和操作不同关系型数据库,简化数据库操作,提高Java应用程序的可移植性和可维护性。使用JDBC进行数据库操作主要包括创建数据源对象、建立连接、构造和执行SQL语句及释放资源等步骤。此外,还可以使用Set系列方法设置值,并使用get系列方法获取查询结果。

Java Database Connectivity(JDBC)是Java语言中用于访问关系型数据库的标准接口。它定义了一组API,使得Java程序能够以统一的方式连接、访问和操作不同的关系型数据库。JDBC不仅简化了数据库操作,还提高了Java应用程序的可移植性和可维护性。

1. 下载并导入MySQL驱动jar包

一键直达:https://mvnrepository.com/

下载方法:

简单粗暴版导入方式:

2. 使用JDBC的基本步骤

在Java中使用JDBC与数据库交互,通常包括以下步骤:  

  1. 创建数据源对象,描述了数据从哪里来,数据库服务器的位置
  2. 和数据库服务器建立网络连接
  3. 使用PreparedStatement构造SQL语句
  4. 把SQL发送到服务器上执行
  5. 释放资源

2.1. 创建数据源对象

首先需要创还能数据源对象,描述了数据从哪里来,数据库服务器的位置

url说明:

2.2. 建立连接

把上面的信息都补充完毕之后就可以和数据库服务器建立网络连接了

Connection connection = mysqlDataSource.getConnection();

如果说上面创建数据源对象或是设置信息时有误,这里的连接就会抛出异常

同时要注意选择的是java.sql下的Connection接口

2.3. 创建SQL语句

String sql = "insert into student values('赵六',80)";
PreparedStatement statement = connection.prepareStatement(sql);

这里创建sql语句时不需要加 ‘;’,在控制台中添加分号是因为控制台需要知道当前输入的enter是换行还是执行当前sql,如果说字符串中包含多条sql是需要加的

2.4. 执行SQL

int l = statement.executeUpdate();
System.out.println(l);

这里的方法返回值代表有几行数据受到了影响

2.5. 释放资源

statement.close();
connection.close();

释放资源还是采用先开后关的原则

public class TestJDBC1 {
    public static void main(String[] args) throws SQLException {
        //创建数据源对象,描述了数据从哪里来,数据库服务器的位置
        MysqlDataSource mysqlDataSource = new MysqlDataSource();
        mysqlDataSource.setUrl("jdbc:mysql://127.0.0.1:3306/test2?characterEncoding=utf8&useSSL=false");
        mysqlDataSource.setUser("root");
        mysqlDataSource.setPassword("1234");
        //和数据库服务器建立网络连接
        Connection connection = mysqlDataSource.getConnection();
        System.out.println(connection);
        //使用PreparedStatement构造SQL语句
        String sql = "insert into student values('赵六',80)";
        PreparedStatement statement = connection.prepareStatement(sql);
        //把SQL发送到服务器上执行
        int l = statement.executeUpdate();
        System.out.println(l);
        //释放资源
        statement.close();
        connection.close();
    }
}

3. 使用Set系列方法设置值

在上面的演示中,我们是把一条SQL语句写死了,不够灵活,可以添加键盘录入的方式

但是这样的方式也有弊端,首先就是编写容易出错,其次就是可能会引起“sql注入攻击”,推荐使用下面的方式:

public class TestJDBC2 {
    public static void main(String[] args) throws SQLException {
        Scanner sc = new Scanner(System.in);
        String name = sc.nextLine();
        int grade = sc.nextInt();
        //这里采用另一种方式来创建数据源对象
        DataSource dataSource = new MysqlDataSource();
        ((MysqlDataSource) dataSource).setUrl("jdbc:mysql://127.0.0.1:3306/test2?characterEncoding=utf8&useSSL=false");
        ((MysqlDataSource) dataSource).setUser("root");
        ((MysqlDataSource) dataSource).setPassword("ljl0909");
        //和数据库服务器建立网络连接
        Connection connection = dataSource.getConnection();
        System.out.println(connection);
        //使用PreparedStatement构造SQL语句
        String sql = "insert into student values(?,?)";
        PreparedStatement statement = connection.prepareStatement(sql);
        statement.setString(1, name);
        statement.setInt(2, grade);
        //把SQL发送到服务器上执行
        int l = statement.executeUpdate();
        System.out.println(l);
        //释放资源
        statement.close();
        connection.close();
    }
}

可以根据具体类型选取不同的方法

4. 使用get系列方法获取值

update / delete操作和insert into 方法类似,都是使用executeUpdate(),查询操作使用的是executeQuery()方法,返回值肯定就不是影响的行数了,而是把查询到的数据存放在结果集合中,通过遍历结果集合,就可以达到查询的效果

public class TestJDBC3 {
    public static void main(String[] args) throws SQLException {
        //创建数据源对象
        MysqlDataSource mysqlDataSource = new MysqlDataSource();
        mysqlDataSource.setUrl("jdbc:mysql://127.0.0.1:3306/test2?characterEncoding=utf8&useSSL=false");
        mysqlDataSource.setUser("root");
        mysqlDataSource.setPassword("ljl0909");
        //和数据库建立网络连接
        Connection connection = mysqlDataSource.getConnection();
        //使用PreparedStatement构造SQL语句
        String sql = "select * from student";
        PreparedStatement statement = connection.prepareStatement(sql);
        //执行SQL,查询结果存储在结果集中
        ResultSet resultSet = statement.executeQuery();
        //遍历结果集
        while (resultSet.next()) {
            System.out.println(resultSet.getString("name"));
            System.out.println(resultSet.getInt("grade"));
        }
        //关闭资源
        resultSet.close();
        statement.close();
        connection.close();
    }
}

在使用get方法获取值时要根据具体类型选择相应的get方法,并且传入的参数要和目标列的列名对应

在关闭资源时,比更新操作还多了一个ResultSet对象需要关闭

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
3月前
|
SQL 数据库
jdbc10
jdbc10
23 1
|
7月前
|
Java 关系型数据库 MySQL
JDBC是真的啰里啰嗦啊-但是很重要!(上)
JDBC是真的啰里啰嗦啊-但是很重要!
42 1
|
7月前
|
SQL Java 数据库连接
JDBC是真的啰里啰嗦啊-但是很重要!(下)
JDBC是真的啰里啰嗦啊-但是很重要!
30 1
|
XML 存储 Java
什么是jdbc?为什么要用jdbc
什么是jdbc?为什么要用jdbc
|
SQL Oracle 数据可视化
|
7月前
|
存储 Java 数据库连接
JDBC简单总结
JDBC简单总结
|
缓存 druid Java
JDBC2.0
JDBC2.0在1.0版本java.sql.*上增加了一个扩展包javax.sql.*包,这个包里面包含两个接口: 1.DataSource,数据源。 2.ConnectionPoolDataSource,数据池。 DataSource的源码可以看到,这个接口的作用就是拿来获取connection连接的。 各个数据库厂商只负责实现connection, 至于获取connection,在JDBC1.0里面是由DriverManager来负责的。 JDBC2.0版本之所新增DataSource,原因很简单——数据库连接池。1.0版本时每用一次connection都需要重新new,而da
133 0
JDBC2.0
|
SQL 缓存 关系型数据库
JDBC的“那些事“之应当注意的问题(下)
JDBC的“那些事“之应当注意的问题(下)
|
SQL 人工智能 数据可视化
JDBC的“那些事“之应当注意的问题(上)
JDBC的“那些事“之应当注意的问题(上)
|
SQL Java 关系型数据库
JDBC介绍
JDBC介绍
115 0