关闭

Dao层的数据库的持续化过程中批量加入数据

79人阅读 评论(0) 收藏 举报

加入一条数据使用executeQuery();使用循环插入也可以实现多条语句更新,但是没有executeBatch()方法效率高

加入多条数据使用到executeBatch()方法;

public void addFlowCardDetail(List<FlowCardDetail> flowCardDetails,

            String vouNo)throws DaoException {
      
        System.out.println("----addFlowCardDetail() DAO-");
        Connection conn = null;
        PreparedStatement pstmt = null;
        try{
            conn = ThreadLocalConnection.getConnection();
            String sql = "insert into t_flow_card_detail(vou_no,aim_id,item_no,qty) values (?, ?, ?, ?)";
            pstmt = conn.prepareStatement(sql);
            for(FlowCardDetail flowCardDetail : flowCardDetails){
                pstmt.setString(1, flowCardDetail.getVouNo());
                pstmt.setString(2, flowCardDetail.getAim().getId());
                pstmt.setString(3, flowCardDetail.getItem().getItemNo());
                pstmt.setDouble(4, flowCardDetail.getQty());
                pstmt.addBatch();
            }
            pstmt.executeBatch();//整体更新
        }catch(SQLException e){
            e.printStackTrace();
        }finally{
            DBUtil.close(pstmt);
        }
0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:2659次
    • 积分:127
    • 等级:
    • 排名:千里之外
    • 原创:10篇
    • 转载:2篇
    • 译文:0篇
    • 评论:0条
    文章分类