用java实现excel数据批量导入数据库

 
 

不管是做软件还是做网站,相信很多人在做的时候都要用到数据库,而数据库的数据从何而来呢,可以使手动添加的,但是大多数情况下我们使用的是已有的数据,我们想借助开发的工具管理目前已有的数据,如果是小量的数据,手动录入也无妨,但是对于大量数据呢,手动录入显然已经不显示,而且,更多的时候,我们呢想在软件上增加一个数据的批量导入,这样不管是谁在用这款软件,都可以方便的管理已有数据,那么我们最常用的数据管理器是什么呢,毫无疑问Excel,但是我们做软件是几乎没有人会使用Excel作为DB,所以我们遇到的问题就是如何在软件中实现数据批量导入,数据源是Excel,有人会说用ODBC啊,可以导入到任何地方,但是这种做法好像没有什么技术含量,而且让用户没次批量导入的时候都设置一个ODBC数据源是不现实的,今天博主将给大家介绍用春java实现读取Excel数据文件放入Access数据库(各个数据库的原理是一样的),我们用到的是一个开源API,jxl,代码如下:

public static boolean readExcel(String filePath){
  boolean success=false;
  Workbook rwb = null;
  try{
   InputStream is = new FileInputStream(filePath);
   rwb = Workbook.getWorkbook(is);
   // 获取第一张Sheet表
   Sheet rs = rwb.getSheet(0);
   for (int k = 1; k < rs.getRows(); k++){
    String major=rs.getCell(0, k).getContents();
       String year=rs.getCell(1,k).getContents();
    String class1=rs.getCell(2, k).getContents();
    String number1=rs.getCell(3, k).getContents();
    String name=rs.getCell(4, k).getContents();
    String sex=rs.getCell(5, k).getContents();
    String people=rs.getCell(6, k).getContents();
    String area=rs.getCell(7, k).getContents();
    String birth=rs.getCell(8, k).getContents();
    String bodyid=rs.getCell(9, k).getContents();
    String phone=rs.getCell(10, k).getContents();
    String hostel=rs.getCell(11, k).getContents();
    String father=rs.getCell(12, k).getContents();
    String mather=rs.getCell(13, k).getContents();
    String tel=rs.getCell(14, k).getContents();
    String studentstate=rs.getCell(15, k).getContents();
    String level1=rs.getCell(16, k).getContents();
    String party=rs.getCell(17, k).getContents();
    String duties=rs.getCell(18, k).getContents();
    String english=rs.getCell(19, k).getContents();
    String computer=rs.getCell(20, k).getContents();
    String address=rs.getCell(21, k).getContents();
    String personstation=rs.getCell(22, k).getContents();
    String fundingstation=rs.getCell(23, k).getContents();
    String awardstation=rs.getCell(24, k).getContents();
    String punishmentstation=rs.getCell(25,k).getContents();
    String other1=rs.getCell(26, k).getContents();
    String picturepath="";
    if(major.equals("")||class1.equals("")||name.equals("")||number1.equals("")){
     success=false;
     break;
    }else{
     String str1="insert intoinformation(major,year,class1,number1,name,sex,people,area,birth,bodyid,phone,hostel,father,mather,tel,studentstate,level1,party,duties,english,computer,address,personstation,fundingstation,awardstation,punishmentstation,other1,picturepath)values('"+major+"','"+year+"','"+class1+"','"+number1+"','"+name+"','"+sex+"','"+people+"','"+area+"','"+birth+"','"+bodyid+"','"+phone+"','"+hostel+"','"+father+"','"+mather+"','"+tel+"','"+studentstate+"','"+level1+"','"+party+"','"+duties+"','"+english+"','"+computer+"','"+address+"','"+personstation+"','"+fundingstation+"','"+awardstation+"','"+punishmentstation+"','"+other1+"','"+picturepath+"')";
        CommonCode.addInfo(str1);
        CommonCode.closeAll(); 
        success=true;
         }
   }
   rwb.close();
  }catch (Exception e){
   e.printStackTrace();
  }
  return success;

 } 

转载于:https://www.cnblogs.com/CCDS01/p/7885186.html

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值