- 1、本文档共7页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
大数据导出方法
大数量据导出设计
导出方法设计思路有以下几点
1、 导出数据的格式采用CSV或者可转换xls的htm格式
2、 控制一次最大的导出数量,如果超过上限分多次导出。
3、 从数据库中读取数据后不放入集合类的容器,而是直接使用IO写入本地文件,读取一条写入一条或者合并到一定数量批量写入。
4、 导出完成后提示下载链接,让用户自行下载,而不是采用原先直接放入response弹出下载,以此减少数据流量加快导出速度。
示例
小数据量的导出
商务领航原先采用的皆是此方法,先将数据从数据库中取出然后放入集合容器中,最后再通过response导出数据流,此方法优点是适合小量数据的导出,而且可以做的比较通用。不足之处是资源占用较大,大数据量时jvm内存占用高。
public static void testExport1(){
DBConnEX db = null;
BufferedWriter buf = null;
String sql = select * from biz_moon_log t order by t.id desc;
File f = new File(d:/log2.csv);
Connection conn = null;
StringBuffer stb = null;
List list = null;
long star = System.currentTimeMillis();
System.out.println(star);
try {
list = new ArrayList();
buf = new BufferedWriter(new FileWriter(f));
db = new DBConnEX();
conn = db.getConnection();
Statement stmt = conn.createStatement();
ResultSet rs = stmt.executeQuery(sql);
while(rs.next()){
stb = new StringBuffer();
stb.append(rs.getString(1)+,);
stb.append(rs.getString(2)+,);
stb.append(rs.getString(3)+,);
stb.append(rs.getString(4)+,);
stb.append(rs.getString(5)+,);
stb.append(rs.getString(6));
list.add(stb.toString());
// buf.write(stb.toString());
stb = null;
}
for(int i = 0;ilist.size();i++){
String s = (String)list.get(i);
buf.write(s);
}
buf.close();
} catch (Exception e) {
e.printStackTrace();
}finally{
Util.disConnection(conn);
}
long end = System.currentTimeMillis();
System.out.println(end);
System.out.println(总耗时:+(end - star)+ 毫秒);
}
CSV格式导出
此方法针对前一方法进行了改进,不需要将数据缓存在集合类的容器中,从数据库读取数据时直接调用IO导出,此方法导出数据较快,占用资源少。但不够通用,只是方法过程的改进,格式也仅是纯文本。但纯文本的CSV格式可以被excell识别打开。
public static void testExport2(){
DBConnEX db = null;
BufferedWriter buf = null;
String sql = select * from biz_moon_log t order by t.id desc;
File f = new File(d:/log1.csv);
Connection conn = null;
StringBuffer stb = null;
long star = System.currentTimeMillis();
System.out.println(star);
try {
buf = n
您可能关注的文档
- M1U1P7.ppt
- B2 U2 Using language.ppt
- unit4He said....ppt
- VBA操控文件.doc
- 整式加减去括号PPT.ppt
- 七年级英语下册:Module_10_Life_history_Unit_1课件外研版.ppt
- Unit 2(课件5).ppt
- Excel VBA_ADO+SQL实例集锦.doc
- unit 14 food matters.ppt
- 新版五年级英语上Lesson14.ppt
- JJF(烟草)4.2-2024烟草及烟草制品 连续流动法测定常规化学成分测量不确定度评定指南 第2部分:总植物碱.pdf
- JJG(烟草)33-2024卷烟爆珠强度测试仪检定规程.pdf
- JJF(烟草)4.5-2024烟草及烟草制品 连续流动法测定常规化学成分测量不确定度评定指南 第5部分:钾.pdf
- 计量规程规范 JJF(烟草)4.5-2024烟草及烟草制品 连续流动法测定常规化学成分测量不确定度评定指南 第5部分:钾.pdf
- JJF(烟草)4.4-2024烟草及烟草制品 连续流动法测定常规化学成分测量不确定度评定指南 第4部分:氯.pdf
- 《JJF(烟草)4.4-2024烟草及烟草制品 连续流动法测定常规化学成分测量不确定度评定指南 第4部分:氯》.pdf
- 计量规程规范 JJF(烟草)4.4-2024烟草及烟草制品 连续流动法测定常规化学成分测量不确定度评定指南 第4部分:氯.pdf
- 《JJF(烟草)4.1-2024烟草及烟草制品 连续流动法测定常规化学成分测量不确定度评定指南 第1部分:水溶性糖》.pdf
- 南京金牛湖两山产业投资开发有限公司招聘笔试题库2024.pdf
- 瑞金市乡村发展投资建设有限公司招聘笔试题库2024.pdf
文档评论(0)