java实现数据库的数据写入到txt的方法
2017-07-25 08:45
816 查看
本文讲解如何用java实现把数据库的数据写入到txt中 并实现类似下载软件的样子在网页中弹出下载.
package datatest; import java.io.BufferedOutputStream; import java.io.IOException; import java.io.UnsupportedEncodingException; import java.net.URLEncoder; import java.sql.ResultSet; import java.sql.SQLException; import javax.servlet.ServletException; import javax.servlet.ServletOutputStream; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import bean.ConnDB; public class export extends HttpServlet { public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //设置编码 response.setCharacterEncoding("UTF-8"); //连接数据库 ConnDB conn = new ConnDB(); ServletOutputStream outputstream = null; BufferedOutputStream buffoutputstream = null; String txt_name = "导出的txt文件名.txt";//导出的txt文件名 try { response.reset();// 清空输出流 response.setContentType("text/plain;charset=utf-8"); //设置txt文件名称编码,防止中文乱码 response.setHeader("Content-disposition", "attachment; filename="+URLEncoder.encode(txt_name, "UTF-8")); StringBuffer write = new StringBuffer(); outputstream=response.getOutputStream(); buffoutputstream = new BufferedOutputStream(outputstream); //根据id查询数据库 int id=Integer.parseInt(request.getParameter("id")); String sql = "select a.id,name,account,password "; sql+="from test_rank a "; sql+="left join test_join b on b.id=a.id where a.id="+id; ResultSet rs = conn.doQuery(sql); String content=""; try { while(rs.next()) { //把数据库中读取的数据写入 content=rs.getString("name")+"\r\n";//在txt中换行为\t\n write.append(content); content=rs.getString("account")+"\r\n"; write.append(content); break; } } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } //write.append(content); //设置编码 防止中文乱码 String str = new String(write.toString().getBytes(),"gbk"); buffoutputstream.write(str.toString().getBytes("gbk")); buffoutputstream.flush(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } finally { if (outputstream != null) try { outputstream.close(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } if (buffoutputstream != null) try { buffoutputstream.close(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { this.doGet(request, response); } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
相关文章推荐
- 用java实现把数据库的数据写入到txt中
- 用java实现在txt文本中写数据和读数据的方法
- 把数据从txt文本文件导入到数据库的实现方法
- Java实现数据批量导入数据库(优化速度-2种方法)
- Java+SpringMVC中自实现定时加载更新数据库数据到内存的方法
- JAVA实现网页爬虫及将数据写入数据库
- java实现从数据库读取数据写入excel,写入多个sheet,6万数据耗时100秒附近
- Python实现读写sqlite3数据库并将统计数据写入Excel的方法示例
- Java实现批量向mysql写入数据的方法
- java实现excel数据重新写入数据库
- java SpringMVC中 POI读取数据库数据并写入Excel表格中,并实现下载功能
- Python实现读取TXT文件数据并存进内置数据库SQLite3的方法
- Java实现从数据库导出大量数据记录并保存到文件的方法(转)
- 用java实现从txt文本文件批量导入数据至数据库
- Java实现批量导入excel表格数据到数据库中的方法
- Java实现从数据库导出大量数据记录并保存到文件的方法
- Java实现数据批量导入数据库(优化速度-2种方法)
- sql server 2005 中文件组的的概念及数据库文件因文件组满而无法写入的数据的解决方法
- 主流数据库之间对SQL:2003标准的不同实现方法比较(第六部分 基础数据类型之BOOLEAN)
- java中删除数据库中重复数据的几个方法-Java基础-Java-编程开发