思路:

第一是文件上传,可以参照Jakarta的FileUpload组件,用普通的Post也就行了。
第二是Excel解析,用JSL或者POI都行
第三是数据保存,这个应该简单吧,一个循环,一行对应一条数据,写好了方法循环赋值调用就行了。
第四是查询和显示,这个更简单了,不用多说。
第一,上传

SmartUpload mySmartUpload = new SmartUpload();

// 时间转换
SimpleDateFormat formatter = new SimpleDateFormat("yyyyMMddHHmmss");
SimpleDateFormat formatter1 = new SimpleDateFormat("yyyyMM");
boolean sign = true;

String date1 = formatter1.format(new Date());
String date2 = "";
String ext = "";

// 获取当前项目路径
String path = config.getServletContext().getRealPath("/");
String path1 = path + "upload/excel/" + date1;
System.out.println("上传的文件目录为:"+path1);

// 创建文件夹
File dirFile = null;
try {
dirFile = new File(path1);
dirFile.mkdirs();
} catch (Exception e) {
e.printStackTrace();
System.out.println(e);
}
try {
// 初始化
mySmartUpload.initialize(config, request, response);

// 设定允许上传的文件(通过扩展名限制),仅允许excel文件
mySmartUpload.setAllowedFilesList("xls");

// 上传
mySmartUpload.upload();

// 获取文件后缀名
ext = mySmartUpload.getFiles().getFile(0).getFileExt();

// 生成文件名
date2 = formatter.format(new Date());

// 保存
mySmartUpload.getFiles().getFile(0).saveAs(path1 + "/" + date2 + "." + ext);

} catch (Exception e) {
e.printStackTrace();
sign = false;
}

if (sign == true) {
String apkPath = "upload/excel/" + date1 + "/" + date2 + "." + ext;

String version = mySmartUpload.getRequest().getParameter("version");
Map<String, Object> vers = new HashMap<String, Object>();

vers.put("version", version);
vers.put("apk", apkPath);
int result = 0;
result = versionDao.addVersion(vers);
if (result > 0) { //上传成功

第二 ,解析

// poi解析
FileInputStream fis=null;
List<UserInfo> list=new ArrayList<UserInfo>();
try {
System.out.println("开始解析数据。。。。。");
String fi=dirFile+"/"+date2+"." + ext;
System.out.println("解析的文件:"+fi);
fis=new FileInputStream(dirFile+ "/" +date2 + "." + ext);
HSSFWorkbook book=new HSSFWorkbook(fis);
HSSFSheet sheet=book.getSheetAt(0);//第一个sheet
int lastRowNum=sheet.getLastRowNum();//最大行数 有数据的
//一般excel第一行是标题
HSSFRow row=null;
for (int i = 1; i < lastRowNum; i++) {
row=sheet.getRow(i);
String num=getCellValue(row, 0);
String name=getCellValue(row, 1);
String address=getCellValue(row, 2);
String mail=getCellValue(row, 3);
UserInfo info=new UserInfo(num, name, address, mail);
list.add(info);
System.out.println("读取内容:"+num+","+name+","+address+","+mail+",");
}
System.out.println("内容:"+list+"。");
// out.print("<script>alert('添加ok!');location.href='versionAdd.jsp'</script>");
} catch (Exception e) {
System.out.println("excel解析出错!!!");
e.printStackTrace();
}
// 解析结束

第三,插入数据库

//解析excel成功
//下面操作入库
response.getWriter().println("excel data:<br/>");
for (UserInfo info : list) {
response.getWriter().println("name:"+info.getName()+" address:"+info.getAddress()+" mail:"+info.getMail()+"<br/>");
System.out.println("名称:"+info.getName()+"地址:"+info.getAddress()+"邮箱:"+info.getMail());
//jdbc链接数据库操作 一条条插入,这个不用我再写了吧???
int r=versionDao.addV2(info);
if(r>0){
System.out.println("插入成功!");
}

第四,读取。。。。(略)

excel批量导入数据库SQL server的更多相关文章

  1. 解决将Excel表导入到SQL Server数据库时出现Text was truncated or one or more characters had no match in the target code错误

    编写python爬虫程序可以在电商.旅游等网站上爬取相关评论数据,这些数据可以用于词云制作.感情词分析.提取关键词等,也可以将爬取下来的数据以自己的方式进行展示.评论数据爬取下来后,就要考虑怎样入库, ...

  2. VBS将本地的Excel数据导入到SQL Server中

    VBS将本地的Excel数据导入到SQL Server中 高文龙关注0人评论1170人阅读2017-05-14 12:54:44 VBS将本地的Excel数据导入到SQL Server中 最近有个测试 ...

  3. MVC3学习:将excel文件导入到sql server数据库

    思路: 1.将excel文件导入到服务器中. 2.读取excel文件,转换成dataset. 3.循环将dataset数据插入到数据库中. 本例子使用的表格为一个友情链接表F_Link(LinkId, ...

  4. 如何把EXCEL数据导入到SQL SERVER数据库中 (转)

    转:http://blog.csdn.net/jjp837661103/article/details/13509889 在我们完成一个项目开发之后,通常我们需要把客户的很多数据导入到数据库中,面对大 ...

  5. Excel数据导入到Sql server

    问题:数据库内直接操作导致 错误 0xc020901c: 数据流任务 1: 源 - yndata1$.输出[Excel 源输出] 上的 源 - yndata1$.输出[Excel 源输出].列[ind ...

  6. 批量还原数据库 SQL Server 2008

    1.如果你够懒,不想一步一步点路径,一步一步选择 2.如果你连单个备份数据库的存储过程都不想多执行,一般每还原一个需要修改数据库名 下面的脚本适合你: /*********************** ...

  7. C# 从Excel 批量导入数据库

    最近遇到了关于 C# MVC 批量添加数据的问题,解决后就自己写了一个未完成的小Demo  不管什么编程语言都会提供操作Excel文件的方式,C#操作Excel主要有以下几种方式: 1.Excel 说 ...

  8. 关于如何将Excel数据导入到SQL Server中

    面对大量的Excel数据我们可能会非常苦恼,如果一条一条的插入到数据库:不仅会耗大量的时间,而且还可能会发生错误,现在我来说一下如何导入数据! 1.准备工作 首先要在Excel中建立数据表对应的数据字 ...

  9. Excel批量插入的SQL Server

    首先新建一个WPF的项目,名为ExcelToServerDemo 到Nuget去安装NPOI的Nuget包,点击安装即可,会自动引用项目. 新建一个Student的表格,有名字,年龄,性别,地址,以及 ...

随机推荐

  1. ucosii(2.89)mbox 应用要点

    OSMboxCreate(void *msg)     当创建一个mbox时候,消息邮箱允许(任务或者中断)向其他一个或者几个任务发送消息.初始化msg指向消息邮箱中的消息. void*OSMboxP ...

  2. navicat 常用快捷键

    1.ctrl+q           打开查询窗口 2.ctrl+/            注释sql语句3.ctrl+shift +/  解除注释4.ctrl+r           运行查询窗口的 ...

  3. 原 荐 使用Spring Boot Actuator、Jolokia和Grafana实现准实时监控

    原 荐 使用Spring Boot Actuator.Jolokia和[可视化]Grafana实现准实时监控.   监控系统:          日志- 基础处理 - 表格 - 可视化一体化解决方案. ...

  4. 任务十一:移动Web页面布局实践

    面向人群: 有一定HTML及CSS基础,想要尝试移动开发 难度: 中 重要说明 百度前端技术学院的课程任务是由百度前端工程师专为对前端不同掌握程度的同学设计.我们尽力保证课程内容的质量以及学习难度的合 ...

  5. vue axios 请求本地接口端口不一致出现跨域设置代理

    首先在config下面的index.js,设置跨域代理 在axios请求的时候     用'/api/' 替代baseURL 最重要的就是设置完必须重新 npm run dev 否则不生效

  6. 欧拉函数φ(x)简要介绍及c++实现

    我还是很喜欢数论,从此吃喝不问,就此沉沦. 欧拉函数φ(x)的值为在[1,x)的区间内与x互质的数的个数 通式:    其中p1, p2……pn为x的所有质因数,x是不为0的整数.φ(1)=1. 注意 ...

  7. CF-1027-B. Curiosity Has No Limits

    CF-1027-B. Curiosity Has No Limits http://codeforces.com/contest/1072/problem/B 题意: 给定两组序列a,b,长度为n-1 ...

  8. html块级元素和行级元素的区别和使用

    行内.块状元素区别: 1.行内元素与块级函数可以相互转换,通过修改display属性值来切换块级元素和行内元素,行内元素display:inline,块级元素display:block. 2.行内元素 ...

  9. 数据结构( Pyhon 语言描述 ) — —第9章:列表

    概念 列表是一个线性的集合,允许用户在任意位置插入.删除.访问和替换元素 使用列表 基于索引的操作 基本操作 数组与列表的区别 数组是一种具体的数据结构,拥有基于单个的物理内存块的一种特定的,不变的实 ...

  10. AtCoder Beginner Contest 098 D - Xor Sum 2

    D - Xor Sum 2 Time limit : 2sec / Memory limit : 1024MB Score : 500 points Problem Statement There i ...