【Java】JDBC编程实现对数据库表的增删改查操作

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 【Java】JDBC编程实现对数据库表的增删改查操作

1.增

编写向数据库表增加一条记录的测试类代码(AddDemo1)

代码

package test1;
 
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;
 
public class AddDemo {
private static Statement statement;
private static Statement createStatement;
 
public static void main(String[] args) throws ClassNotFoundException, SQLException {
    // 1、加载驱动
    Class.forName("com.mysql.cj.jdbc.Driver");// 反射技术,保证内存中只有一个Driver对象
    // 2、创建连接
    String url="jdbc:mysql://localhost:3306/jdbc?serverTimezone=GMT%2B8&characterEncoding=utf8&useSSL=true";
    String user="root";// 数据库用户名
    String pw="123456";// 数据库密码(每个人都不一样我的是123456)
    Connection conn=DriverManager.getConnection(url, user, pw);//补全快捷键ctrl+1
    System.out.println(conn);//测试是否连接上mysql数据库
    // 3、得到执行sql语句的对象
    java.sql.Statement statement = conn.createStatement();//补全快捷键ctrl+1
    // 4、执行sql语句,并返回结果
    String sql="INSERT INTO student VALUES(NULL,'tom','男','tom@163.com','18888888888')";//执行语句
    int i=statement.executeUpdate(sql);
    // 5、处理结果
    if (i > 0) {
        System.out.println("添加成功");
    }
    // 6、关闭连接
    statement.close();
    conn.close();
}
}

执行结果
image.png

2.改

编写修改数据库表中一条记录的测试类代码

代码

package test1;
 
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;
 
public class UpdateDemo {
 
    public static void main(String[] args) throws ClassNotFoundException, SQLException {
        Class.forName("com.mysql.cj.jdbc.Driver");
        Connection conn=DriverManager.getConnection("jdbc:mysql://localhost:3306/jdbc?characterEncoding=utf8&useSSL=true", "root", "123456");
        Statement statement = conn.createStatement();
        statement.execute("INSERT INTO student VALUES(NULL,'zhangsan','男','zhangsan@163.com','16666666666')");
        int i=statement.executeUpdate("UPDATE student SET sname='rose',sex='女'  WHERE stuid=2");
        if(i>0) {
            System.out.println("修改成功!");
        }
        statement.close();
        conn.close();
    }
}

执行结果
image.png

image.png

3.查

编写查询数据库表中所有记录的测试类代码

代码

package test1;
 
 
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
 
import com.mysql.cj.xdevapi.Statement;
 
public class FindAllDemo {
public static void main(String[] args) throws ClassNotFoundException, SQLException {
    Class.forName("com.mysql.cj.jdbc.Driver");
    Connection connection=DriverManager.getConnection("jdbc:mysql://localhost:3306/jdbc?characterEncoding=utf8&useSSL=true", "root","123456");
    java.sql.Statement statement=connection.createStatement();
    ResultSet rs = statement.executeQuery("SELECT * FROM student");
    List<Student> stu = new ArrayList<Student>();
    while (rs.next()) {
        Student s = new Student();// 创建一个Student对象
        // 封装Student对象:把每个记录的字段值赋给Student对象的成员变量
        s.setStuld(rs.getInt("stuId"));
        s.setSname(rs.getString("sname"));
        s.setSex(rs.getString("sex"));
        s.setEmail(rs.getString("email"));
        s.setPhone(rs.getString("phone"));
        // 把封装的Student对象添加到stu集合
        stu.add(s);
    }
    stu.forEach(s -> System.out.println(s));
    rs.close();
    statement.close();
    connection.close();
}
}

执行结果
image.png

4.删

编写从数据库表删除一条记录的测试类代码

代码

package test1;
 
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;
 
public class DeleteDemo {
 
public static void main(String[] args) throws ClassNotFoundException, SQLException {
    Class.forName("com.mysql.cj.jdbc.Driver");
    Connection connection=DriverManager.getConnection("jdbc:mysql://localhost:3306/jdbc?characterEncoding=utf8&useSSL=true", "root", "123456");
    Statement statement = connection.createStatement();
    int i= statement.executeUpdate("DELETE FROM student WHERE stuid=2");
    if(i>0) {
        System.out.println("删除成功");
    }
    statement.close();
    connection.close();
}
}

执行结果
image.png

image.png

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
9天前
|
Java 关系型数据库 数据库连接
JDBC:Java与数据库的“黄金搭档”,为何它如此重要?
JDBC:Java与数据库的“黄金搭档”,为何它如此重要?
28 8
|
9天前
|
Java 数据库连接 API
JDBC:Java数据库连接的“黑科技”大揭秘
JDBC:Java数据库连接的“黑科技”大揭秘
24 7
|
9天前
|
SQL Java 数据库连接
为何JDBC是Java开发者的“心头好”?原因竟然这么简单!
为何JDBC是Java开发者的“心头好”?原因竟然这么简单!
20 3
|
9天前
|
SQL Java 关系型数据库
探索Java数据库连接的奥秘:JDBC技术全攻略
探索Java数据库连接的奥秘:JDBC技术全攻略
35 8
|
9天前
|
SQL Java 数据库连接
JDBC之旅:从陌生到熟悉的Java数据库连接之路
JDBC之旅:从陌生到熟悉的Java数据库连接之路
18 8
|
9天前
|
SQL Java 数据库连接
Java开发者必知:JDBC连接数据库的“三大法宝”
Java开发者必知:JDBC连接数据库的“三大法宝”
15 7
|
9天前
|
SQL 安全 Java
JDBC:Java与数据库的“月老红线”,你真的了解它吗?
JDBC:Java与数据库的“月老红线”,你真的了解它吗?
9 1
|
19天前
|
SQL Java 数据库连接
Hibernate 是一款开源 ORM(对象关系映射)框架,封装了 JDBC,允许以面向对象的方式操作数据库,简化了数据访问层的开发。
Hibernate 是一款开源 ORM(对象关系映射)框架,封装了 JDBC,允许以面向对象的方式操作数据库,简化了数据访问层的开发。通过映射机制,它可以自动处理对象与数据库表之间的转换,支持主流数据库,提高了代码的可移植性和可维护性。其核心接口包括 SessionFactory、Session 和 Transaction 等,通过它们可以执行数据库的 CRUD 操作。配置方面,需在项目中引入 Hibernate 及数据库驱动依赖,并创建 `hibernate.cfg.xml` 配置文件来设置数据库连接和 Hibernate 行为参数。
27 1
|
9天前
|
SQL Java 数据库连接
深入剖析JDBC:Java与数据库沟通的“桥梁”与“秘密”
深入剖析JDBC:Java与数据库沟通的“桥梁”与“秘密”
7 0
|
18天前
|
SQL 关系型数据库 MySQL
【揭秘】MySQL binlog日志与GTID:如何让数据库备份恢复变得轻松简单?
【8月更文挑战第22天】MySQL的binlog日志记录数据变更,用于恢复、复制和点恢复;GTID为每笔事务分配唯一ID,简化复制和恢复流程。开启binlog和GTID后,可通过`mysqldump`进行逻辑备份,包含binlog位置信息,或用`xtrabackup`做物理备份。恢复时,使用`mysql`命令执行备份文件,或通过`innobackupex`恢复物理备份。GTID模式下的主从复制配置更简便。
71 2