嵌套循环不会在长度大于1的内部循环中执行查询

时间:2011-08-24 00:39:17

标签: java mysql sql jdbc nested-loops

对不起家伙我无法提供反馈,因为我的其他用户名和密码在这里,无论如何这里是问题:

我正在开发一个基于SOAP的Web服务,其中一部分我必须使用嵌套循环对数据库执行一些查询,问题是内部循环只是在放弃之前只执行一次。这是代码:

for(int i=0; i<selec.length; i++){
  for(int j=0; j<sintom.length;j++){
    var[(i*sintom.length)+j] = 
      "INSERT INTO malattia (nome, eta,  descrizione, sesso, etnia, sintomi) "
      + "VALUES ('" + malattia + "','" + eta + "','" + descrizione + "','" 
      +  sexarra[0] + "','" + selec[i] + "','" + sintom[j] + "')";
  }
}

这是查询应该执行的地方:

if (errore.equals("")) {
  try {
    Statement st = conn.createStatement();
    for(int i=0; i<selec.length; i++){
      for(int j=0;j<sintom.length;j++){
        st.executeUpdate(var[(i*sintom.length)+j]);
      }
    }

无论select的大小如何,只要 sintom 的长度为1,大于1就无效,它将无法正常工作。

更新
我刚刚使用了预处理语句,但问题仍然存在,如果内循环的长度大于1,它将无法工作!这是我所做的更改的代码:

if (errore.equals("")) {
  try {
    /*  Statement st = conn.createStatement();
        Statement[] si=new Statement[selec.length];
        for(int i=0;i<selec.length;i++)
        si[i]=conn.createStatement();               */
   PreparedStatement ps = conn.prepareStatement(
     "INSERT INTO malattia (nome, eta, descrizione, sesso, etnia, sintomi) 
      values (?, ?, ?, ?, ?, ?)");


     for(int i=0; i<selec.length; i++){
       for(int j=0;j<sintom.length;j++){
         //  si[i].executeUpdate(var[(i*sintom.length)+j]);
         ps.setString(1, malattia);
         ps.setInt(2, eta);
         ps.setString(3, descrizione);
         ps.setString(4, sexarra[0] );
         ps.setString(5, selec[i]);
         ps.setString(6, sintom[j]);
         ps.executeUpdate();
       }
     }
   }  
   //st.executeUpdate(q);
   ps.close();
   conn.close();
   ris = "si";

完整的服务器代码:

             public String aggiungi_malattia(String malattia, int eta, String descrizione, String[] sexarra, String[] selec, String[] sintom) {
        String ris = "no";
         String errore = connetti();
         if (errore.equals("")) {
              try {
               PreparedStatement ps = conn.prepareStatement("INSERT INTO malattia (nome, eta, descrizione, sesso, etnia, sintomi) values (?, ?, ?, ?, ?, ?)");
          else {  
            for(int i=0; i<selec.length; i++){
                for(int j=0;j<sintom.length;j++){

                   //  si[i].executeUpdate(var[(i*sintom.length)+j]);
                   ps.setString(1, malattia);
                   ps.setInt(2, eta);
                   ps.setString(3, descrizione);
                   ps.setString(4, sexarra[0] );
                   ps.setString(5, selec[i]);
                   ps.setString(6, sintom[j]);

                   ps.executeUpdate();
                }
               }
            }



                   //st.executeUpdate(q);
                    ps.close();
                    conn.close();
                    ris = "si";
              } catch (SQLException e) {
                    System.out.println("Errore: " + e.getMessage());
                    return ris;
              }
        }
        return ris;
  }

服务器发送 ris si ,具体取决于查询是否成功,此处为 si 如果 sintom 这是内部循环的长度为1,否则我得到我不确切知道是什么导致它以没有此外这是一个基于SOAP的Web服务,我可以调试系统的客户端部分而不是服务器部分

1 个答案:

答案 0 :(得分:0)

在打了我的头几个小时之后,数据库中出现了问题!!发生了什么事情,因为列 sintomi 是一个FK,引用了一个多值的Sintomi表,因此它是表malattia的主键因此我传递的值需要已经存在于表sintomi所以列 sintomi 可以参考它!无论如何,从我提供的信息中无法理解,谢谢大家!事情总是好的,当事情失去控制时,你们就在那里。