JDBC详解

本文涉及的产品
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
简介: 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对象需要关闭

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
应用服务中间件
tomcat修改默认端口详细步骤(包含运行测试)
在tomcat端口被占用或者需要把默认的8080端口换成其他的端口,就可以修改默认端口。
3037 0
tomcat修改默认端口详细步骤(包含运行测试)
|
7月前
|
XML JSON Java
Java 反射:从原理到实战的全面解析与应用指南
本文深度解析Java反射机制,从原理到实战应用全覆盖。首先讲解反射的概念与核心原理,包括类加载过程和`Class`对象的作用;接着详细分析反射的核心API用法,如`Class`、`Constructor`、`Method`和`Field`的操作方法;最后通过动态代理和注解驱动配置解析等实战场景,帮助读者掌握反射技术的实际应用。内容翔实,适合希望深入理解Java反射机制的开发者。
665 13
|
10月前
|
Java 应用服务中间件 API
Servlet开发流程 (里面有Idea项目添加Tomcat依赖详细教程)
本文详细介绍了Servlet的开发流程,包括在IntelliJ IDEA中添加Tomcat依赖的详细教程。通过上述步骤,开发者可以快速搭建并运行一个基本的Servlet应用,理解并掌握Servlet的开发流程对于Java Web开发至关重要。希望本文能够帮助开发者顺利进行Servlet开发,提高工作效率。
1255 78
|
编解码 网络协议 Oracle
java网络编程入门以及项目实战
这篇文章是Java网络编程的入门教程,涵盖了网络编程的基础知识、IP地址、端口、通讯协议(TCP和UDP)的概念与区别,并提供了基于TCP和UDP的网络编程实例,包括远程聊天和文件传输程序的代码实现。
java网络编程入门以及项目实战
|
12月前
|
SQL Java 关系型数据库
使用 JDBC 实现 Java 数据库操作
JDBC(Java Database Connectivity)是 Java 提供的数据库访问技术,允许通过 SQL 语句与数据库交互。本文详细介绍了 JDBC 的使用方法,包括环境准备、编程步骤和完整示例。
1086 7
|
11月前
|
安全 Java 编译器
JAVA泛型类的使用(一)
Java 泛型类是 JDK 5.0 引入的重要特性,提供编译时类型安全检测,增强代码可读性和可维护性。通过定义泛型类如 `Box<T>`,允许使用类型参数。其核心原理是类型擦除,即编译时将泛型类型替换为边界类型(通常是 Object),确保与旧版本兼容并优化性能。例如,`Box<T>` 编译后变为 `Box<Object>`,从而实现无缝交互和减少内存开销。
|
Java 关系型数据库 MySQL
java入门项目:学生管理系统(进阶版超详细搭建)
学生管理系统是一个典型的信息管理系统,熟悉并掌握其需求和设计思想对于理解和学习数据库操作和Java编程有非常大的帮助。 分为学生端和教师端 1. 学生端的功能分为登录、注册、查看个人信息、查看成绩、申请修改信息 2. 教师端的功能分为登录、注册、查看学生信息、修改学生信息、删除学生信息、添加学生信息、查看学生申请的修改信息
13304 3
|
消息中间件 测试技术 领域建模
DDD - 一文读懂DDD领域驱动设计
DDD - 一文读懂DDD领域驱动设计
46748 6
|
Dubbo Java 应用服务中间件
Java从入门到精通:3.2.2分布式与并发编程——了解分布式系统的基本概念,学习使用Dubbo、Spring Cloud等分布式框架
Java从入门到精通:3.2.2分布式与并发编程——了解分布式系统的基本概念,学习使用Dubbo、Spring Cloud等分布式框架
1073 0
|
SQL 存储 Java
JDBC API 万字详解(通俗易懂)
JDBC 第二节 详解API 通俗易懂!
817 0