36906627 2017-09-20 08:31 采纳率: 0%
浏览 1901

java:prepareStatement先后执行两次查询出现混乱

public ArrayList<MonmentMsg> getAllMontMsg() throws Exception {
    ArrayList<MonmentMsg> allMontMsg = new ArrayList<MonmentMsg>();
    String sql = "SELECT id,user,time,message,imgSrc FROM monment";
    pstm = conn.prepareStatement(sql);
    ResultSet rs = pstm.executeQuery();
    while (rs.next()) {
        MonmentMsg monmentMsg = new MonmentMsg();
        int montId=rs.getInt(1);
        monmentMsg.setId(montId);
        monmentMsg.setSender(rs.getString(2));
        monmentMsg.setMontTime(rs.getString(3));
        monmentMsg.setMessage(rs.getString(4));
        if (rs.getString(5) != null) {          
        String imgSrc = rs.getString(5);// 将绝对路径修改为相对路径
        String temp[] = imgSrc.split("\\\\");
        // for(String element:temp){
        // System.out.println("长度是:"+temp.length);
        // System.out.println(element);
        // }
        int length = temp.length;
        String newImgSrc = "../" + temp[length - 2] + "/" + temp[length - 1];
        System.out.println("新的imgsrc:" + newImgSrc);
        monmentMsg.setImgSrc(newImgSrc);
        }else {
            monmentMsg.setImgSrc("");
        }

        //获取当前动态的所有回复记录
        String getMontMsgSonSql="select user,message from monmentSon where id=?";
        pstm=conn.prepareStatement(getMontMsgSonSql);
        pstm.setInt(1, montId);

        ResultSet rsSon=pstm.executeQuery();
        ArrayList<MontSon> montSonList=new ArrayList<>();
        while (rsSon.next()) {
            System.out.println("回复的用户id"+rs.getString(1));
            System.out.println("回复的内容"+rs.getString(2));
            MontSon montSon=new MontSon();
            montSon.setUser(rs.getString(1));
            montSon.setMessage(rs.getString(2));
            montSonList.add(montSon);
        }
        monmentMsg.setMontSon(montSonList);
        allMontMsg.add(monmentMsg);
    }
    return allMontMsg;
}
  • 写回答

2条回答 默认 最新

  • m0_37535086 2017-09-20 10:18
    关注

    pstm变量两个设置成不一样的我觉得应该,但求采纳。

    评论

报告相同问题?

悬赏问题

  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog