梧桐 2024-03-28 16:57 采纳率: 0%
浏览 9

(标签-JAVA|关键词-while)

JAVA调用数据库写入chart数据信息,前面用while遍历数据(数据只有一行),后面嵌套一个while遍历数据(数据有五行),而且不是一列,但是后面嵌套的受前面影响,只能出来第一行数据。

img

img

  • 写回答

1条回答 默认 最新

  • 码农阿豪 Java领域优质创作者 2024-03-29 00:00
    关注
    让阿豪来帮你解答,本回答参考chatgpt3.5编写提供,如果还有疑问可以评论或留言
    问题描述:在JAVA调用数据库写入chart数据信息时,前面用while遍历数据(数据只有一行),后面嵌套一个while遍历数据(数据有五行),而且不是一列,但是后面嵌套的受前面影响,只能出来第一行数据。 解决方案:
    1. 确认数据库表中数据的存储方式,是以行还是列进行存储;
    2. 确认数据的存储类型,是否为字符串类型或其他类型,并进行相应的数据类型转换;
    3. 对于数据量较大的情况,可以使用PreparedStatement和ResultSet来进行操作;
    4. 在嵌套的while循环中,需要对前面while循环中的结果进行筛选,以获取正确的数据;
    5. 将获取到的数据存入相应的数据结构中,用于生成chart。 示例代码:
    //获取数据库连接
    Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/test", "root", "root");
    //创建Statement
    Statement stmt = conn.createStatement();
    //执行SQL语句1
    String sql1 = "SELECT * FROM table1 WHERE id = 1";
    ResultSet rs1 = stmt.executeQuery(sql1);
    //遍历结果集1
    while (rs1.next()) {
        //获取数据
        String data1 = rs1.getString("field1");
        //执行SQL语句2
        String sql2 = "SELECT * FROM table2 WHERE field2 = '" + data1 + "'";
        ResultSet rs2 = stmt.executeQuery(sql2);
        //遍历结果集2
        while (rs2.next()) {
            //获取数据
            String data2 = rs2.getString("field1");
            int count = rs2.getInt("count");
            //将数据存入相应的数据结构中
            //...
        }
    }
    //关闭连接
    rs1.close();
    stmt.close();
    conn.close();
    
    评论

报告相同问题?

问题事件

  • 创建了问题 3月28日

悬赏问题

  • ¥170 如图所示配置eNSP
  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效
  • ¥15 悬赏!微信开发者工具报错,求帮改
  • ¥20 wireshark抓不到vlan
  • ¥20 关于#stm32#的问题:需要指导自动酸碱滴定仪的原理图程序代码及仿真
  • ¥20 设计一款异域新娘的视频相亲软件需要哪些技术支持
  • ¥15 stata安慰剂检验作图但是真实值不出现在图上
  • ¥15 c程序不知道为什么得不到结果
  • ¥15 键盘指令混乱情况下的启动盘系统重装