java mysql的jdbc批量导入

   /**
     * 批量导入的方法
     * @param receiverList
     * @throws Exception 
     */

private void inserBatch(List<GgEntity> GgList) throws Exception{

        Connection con = null;
        PreparedStatement pst = null;
      
        try{
            Class.forName("com.mysql.jdbc.Driver");
            con = (Connection) DriverManager.getConnection(url,username,this.getPassword());            
            String sql = "insert into Gg(COLUMN_NAME , COLUMN_CODE ,TYPE,PARENT_COLUMN_CODE,status,CREATE_BY,CREATE_TIME) values "
            + "(?,?,?,?,?,?,?)";
            // 关闭事务自动提交
            con.setAutoCommit(false);
                      
            pst = (PreparedStatement) con.prepareStatement(sql);
            int i=0;
            Long start = System.currentTimeMillis();
            if (GgList.size() > 0) {
            for (GgEntity bre : GgList)
            {
            pst.setString(1,bre.getColumnName());
            pst.setString(2, bre.getColumnCode());
            pst.setInt(3, bre.getType());
            pst.setString(4, bre.getParentColumnCode());
            pst.setInt(5, bre.getStatus());
            pst.setLong(6, bre.getCreateBy());
            pst.setTimestamp(7, new Timestamp(System.currentTimeMillis()));


            // 把一个SQL命令加入命令列表
            pst.addBatch();
           
            if (i % 500 == 0){//500条执行一次
            pst.executeBatch();
            con.commit();
            System.out.println("批量插入数据库=======" + i);
            }
            i++;
           
            }
            // 执行批量更新
            pst.executeBatch();
            // 语句执行完毕,提交本事务            
            con.commit();
            Long end  = System.currentTimeMillis();
            System.out.println("=============================插入"+receiverList.size()+"条数据用了"+(end - start)/1000 + "秒");
}
       } catch (ClassNotFoundException e) {
           e.printStackTrace();
       } catch (SQLException e) {
           e.printStackTrace();
       }finally {
           try
          {
              con.setAutoCommit(true);
              con.close();
              pst.close();
          }
          catch (SQLException e)
          {
              
              e.printStackTrace();
          }
          
      }


    }
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值