【问题标题】:insert multiple values using prepared statement using loop java使用循环java使用准备好的语句插入多个值
【发布时间】:2015-01-17 18:25:57
【问题描述】:

我正在尝试使用迭代 (for) 在 mysql 数据库中插入多个值,但它总是插入第一行并停止。

String rq="insert into seance values (?, ?, ?,?,?,?);";

try (Connection cnx = Connecteur1.getConnection(); PreparedStatement pst = cnx.prepareStatement(rq)) {

    for(Etudiant var:liste1)
    {
        if(!(listEntier.contains(var.getCode_etudiant())))
        { 
            pst.setString(1,DateCourant.format(date));
        pst.setString(2,temps.format(date) );
        pst.setInt(3,codeMatiere);
        pst.setInt(4, 0);
        pst.setInt(5,var.getCode_etudiant());
        pst.setInt(6, codeGroupe);

        pst.addBatch();

        }
        else
        {
            pst.setString(1,DateCourant.format(date));
            pst.setString(2,temps.format(date) );
            pst.setInt(3,codeMatiere);
            pst.setInt(4, 1);
            pst.setInt(5,var.getCode_etudiant());
            pst.setInt(6, codeGroupe);

           pst.addBatch();

        }

    }

    pst.executeBatch();
    pst.close();

}

【问题讨论】:

    标签: java mysql prepared-statement multiple-insert


    【解决方案1】:

    你需要:

    cnx.setAutoCommit(false) 
    

    开头

    cnx.commit();
    

    最后

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2016-03-07
      • 2019-09-24
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2013-10-16
      • 1970-01-01
      • 2011-11-03
      相关资源
      最近更新 更多