java对数据库的增删改查

查询步骤

1.准备连接数据库需要的变量 (库名称,库用户名,库密码) 2.提前写好查询数据库的命令 3.声明一个存参数的list 4.连接数据库(创建连接,准备指令,连接) 5.拿到容器,循环容器拿到内容 6.把内容发给前端

1. 建立数据库连接

需要知道数据库名称,用户名,密码

java 复制代码
// 1. 配置连接信息(必须改成你自己的)
String url = "jdbc:mysql://localhost:3306/你的数据库名?useSSL=false&serverTimezone=Asia/Shanghai&allowPublicKeyRetrieval=true";
String user = "root";
String password = "你的MySQL密码";

2. 提前写好数据库命令(编写 SQL 查询语句)

java 复制代码
String sql = "SELECT id,name FROM user";

3. 声明一个存参数的list

java 复制代码
 List<Map<String, Object>> list = new ArrayList<>();

4. 连接数据库预编译SQL=创建 PreparedStatement 对象)

java 复制代码
          创建数据库连接 接水管
                Connection conn = DriverManager.getConnection(url, user, password);
//                创建预处理语句(准备一下)
                PreparedStatement ps = conn.prepareStatement(sql);
//                执行查询并获取结果(开水龙头、接水)
                ResultSet rs = ps.executeQuery()

注:rs打印出来是容器,不是数据库具体内容,要内容只能循环。

5. 循环容器拿到内容

java 复制代码
  while (rs.next()) {
                Map<String, Object> obj = new HashMap<>();
                obj.put("id", rs.getInt("id"));
                obj.put("name", rs.getString("name"));
                list.add(obj);
            }

            // 打印给前端的数组对象格式
            System.out.println("发给前端的数据:");
            System.out.println(list);

6. 把数据发给前端

等我后面添加,感觉有点麻烦。休息休息

整体代码

java 复制代码
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

public class TestQuery {
    public static void main(String[] args) {
//        -------定义连接数据库需要的变量-------
        String url = "jdbc:mysql://localhost:3306/userlist?useSSL=false&serverTimezone=Asia/Shanghai&allowPublicKeyRetrieval=true";
        String user = "root";
        String password = "123456";
//        先从表中,拿到数据
        String sql = "SELECT id,name FROM user";

        // 【关键】list 必须声明在 try 外面,保证作用域正确
//        1.List 声明这是一个有序列表
//        2.<Map<String, Object>> 定义列表的元素是键值对组合的对象
//        3.这个数组包对象的组合叫做list
//        4.new ArrayList<>();创建一个空的、真实可用的列表,里面专门存放你左边规定的那种键值对数据。
//        123部分属于规定,4才是创建
        List<Map<String, Object>> list = new ArrayList<>();

        try (
//               创建数据库连接 接水管
                Connection conn = DriverManager.getConnection(url, user, password);
//                创建预处理语句(装水龙头 / 准备指令)
                PreparedStatement ps = conn.prepareStatement(sql);
//                执行查询并获取结果(开水龙头、接水)
                ResultSet rs = ps.executeQuery()
        ) {
//            打印的rs只是容器,并没有具体内容,要拿到数据库所有内容,只能循环
            System.out.println(rs);
            while (rs.next()) {
                Map<String, Object> obj = new HashMap<>();
                obj.put("id", rs.getInt("id"));
                obj.put("name", rs.getString("name"));
                list.add(obj);
            }

            // 打印给前端的数组对象格式
            System.out.println("发给前端的数据:");
            System.out.println(list);

        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}
相关推荐
zhangjw342 小时前
Java基础语法:变量、数据类型与运算符,从原理到实战
java·开发语言
yaoxin5211235 小时前
384. Java IO API - Java 文件复制工具:Copy 示例完整解析
java·开发语言·python
Greyson15 小时前
Layui表格如何使用第三方插件实现树形展示.txt
jvm·数据库·python
2401_871696525 小时前
mysql行级锁失效的原因排查_检查查询条件与执行计划
jvm·数据库·python
NotFound4865 小时前
实战指南如何实现Java Web 拦截机制:Filter 与 Interceptor 深度分享
java·开发语言·前端
Elastic 中国社区官方博客5 小时前
Elasticsearch:快速近似 ES|QL - 第一部分
大数据·运维·数据库·elasticsearch·搜索引擎·全文检索
Dontla6 小时前
高基数(High Cardinality)问题介绍(Prometheus、高基数字段、低基数字段)
前端·数据库·prometheus
a9511416426 小时前
CSS如何实现元素隐藏不占位_使用display-none完全移除
jvm·数据库·python
SelectDB技术团队7 小时前
SelectDB Enterprise 4.0.5:强化安全与治理,构建企业级实时分析与 AI 数据底座
数据库·人工智能·apache doris