- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
大数量据导出设计
导出方法设计思路有以下几点
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 = new B
您可能关注的文档
最近下载
- 红色革命文化-2025年高考语文作文复习之主题素材积累与运用.pdf VIP
- 中国传媒大学《微视频创意与制作》课件-微视频创意与制作-PPT-微视频创意与制作(第一章).pptx VIP
- 事故救援应急响应专项预案事故救援应急响应专项预案.doc VIP
- 人教版二年级上册数学全册教学设计(配2025年秋新版教材).docx
- 千级无尘室工程施工方案(3篇).docx VIP
- 深度解析《GBT 44037-2024焦炭溶损率及溶损后强度试验方法》.pptx
- 2025 中级注册安全工程师《金属非金属矿山安全》速记口诀.pdf
- 2025年中国吸顶式车载显示器数据监测研究报告.docx
- 九年级化学酸、碱、盐、氧化物知识小结 “三表一图”(二)天津版.doc VIP
- 部编版六年级上册语文第一周(草原-丁香结)达标测评卷 含答案.docx VIP
文档评论(0)