Springmvc 实现数据导出
来源:互联网 发布:苹果手机淘宝比价插件 编辑:程序博客网 时间:2024/06/04 15:38
首先要搞清楚流程,个人理解(错了请不要怪我)就是control-->Service-->dao 还会涉及到实体类
control层
public String Exportable(String beginDate,String endDate,String selforfree,HttpServletResponse resp){
List<Order> export = orderService.export(beginDate,endDate);
new exportExcle().export(export,selforfree, resp);
return "/admin/order/exportData";
}
Service层
List<Order> export(String begin,String end);
Serviceimpl层
public List<Order> export(String begin, String end) {
List<Order> order=orderDao.Export(begin, end);
return order;
}
dao层
List<Order> Export(String begin,String end);
daoImpl层
@Override
public List<Order> Export(String begin, String end) {
String jpql="from Order where createDate between :begin and :end";
List<Order> p = null;
try {
p = (List<Order>) entityManager.createQuery(jpql).setFlushMode(FlushModeType.COMMIT).setParameter("begin", new SimpleDateFormat("yyyy-MM-dd").parse(begin),TemporalType.DATE).setParameter("end", new SimpleDateFormat("yyyy-MM-dd").parse(end),TemporalType.DATE).getResultList();
} catch (ParseException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return p;
}
.setParameter("begin", new SimpleDateFormat("yyyy-MM-dd").parse(begin),TemporalType.DATE) 因为这里是时间类型所以需要转换
com.until 导出文件需要的类
public class exportExcle {
public void export(List<Order> order,String selforfree,HttpServletResponse resp) {
System.out.println("export-Start");
HSSFWorkbook wb = new HSSFWorkbook();
HSSFSheet sheet = wb.createSheet("订单信息");
//设置每一行的宽度
sheet.setColumnWidth(0, 50 * 100);
sheet.setColumnWidth(1, 45 * 100);
sheet.setColumnWidth(2, 20 * 100);
sheet.setColumnWidth(3, 25 * 100);
sheet.setColumnWidth(4, 120 * 100);
sheet.setColumnWidth(5, 35 * 100);
sheet.setColumnWidth(6, 20 * 100);
sheet.setColumnWidth(7, 20 * 100);
sheet.setColumnWidth(8, 20 * 100);
sheet.setColumnWidth(9, 20 * 100);
sheet.setColumnWidth(10, 20 * 100);
sheet.setColumnWidth(11, 20 * 100);
sheet.setColumnWidth(12, 80 * 100);
sheet.setColumnWidth(13, 80 * 100);
HSSFRow row = sheet.createRow(0);
HSSFCellStyle style = wb.createCellStyle();
style.setAlignment(HSSFCellStyle.ALIGN_CENTER);
row.createCell(0).setCellValue("订单号");
row.createCell(1).setCellValue("买家");
row.createCell(2).setCellValue("买家id");
row.createCell(3).setCellValue("收件人");
row.createCell(4).setCellValue("收货人地址");
row.createCell(5).setCellValue("收货人联系方式");
row.createCell(6).setCellValue("订单价格");
row.createCell(7).setCellValue("运费");
row.createCell(8).setCellValue("手续费");
for (int i =0; i < order.size(); i++)
{
row = sheet.createRow(i+1);
Order stu = order.get(i);
row.createCell(0).setCellValue(stu.getSn());
row.createCell(1).setCellValue(new Base64().get(stu.getSeller().getUsername()));
row.createCell(2).setCellValue(stu.getBuyer().getId());
row.createCell(3).setCellValue(stu.getConsignee());
row.createCell(4).setCellValue(stu.getAreaName()+stu.getAddress());
row.createCell(5).setCellValue(stu.getPhone());
row.createCell(6).setCellValue(new DecimalFormat("#.00").format(stu.getAmount()));
row.createCell(7).setCellValue(new DecimalFormat("#.00").format(stu.getFreight()));
row.createCell(8).setCellValue(new DecimalFormat("#.00").format(stu.getFee()));
}
SimpleDateFormat format = new SimpleDateFormat("yyyyMMddHHmmss");
String tablename = null;
if(selforfree.equals("2")){
tablename="会员";
}
else if(selforfree.equals("1")){
tablename="大牌";
}else{
tablename="免单";
}
try
{
String msg = new String(
(tablename+"订单信息_" + format.format(new Date()) + ".xls").getBytes(),
"ISO-8859-1");
OutputStream fout = resp.getOutputStream();
resp.reset();
resp.setContentType("application/vnd.ms-excel");
resp.addHeader("Content-Disposition", "attachment;filename="
+ msg);
wb.write(fout);
fout.flush();
fout.close();
return;
}
catch (Exception e)
{
e.printStackTrace();
}
finally{
System.out.println("export-End");
}
}
- Springmvc 实现数据导出
- SpringMVC列表数据导出
- springmvc实现导出数据信息为excle表格
- springmvc实现导出数据信息为excle表格
- springmvc poi实现报表导出
- springmvc 实现数据验证
- 实现数据导出
- easypoi-springboot/springmvc导出数据为Excel
- java-SpringMVC框架导出Excel格式数据
- SpringMVC实现poi 解析excel 导入导出
- Java +EasyUI+SpringMvc实现Excel导出
- springmvc结合poI实现Execl导出
- SpringMvc+jxl实现excel导入导出
- SpringMVC实现poi 解析excel 导入导出
- 《SpringMvc》---实现JSON数据交互
- perl实现teradata数据导出
- npoi实现数据导出Excel
- PHP方案实现数据导出
- 二进制逻辑运算
- 参考基因组和注释文件下载
- springMVC中web.xml配置/和/*的区别
- c++基础(3)
- 大数乘法的几种算法分析及比较
- Springmvc 实现数据导出
- 快速人群密度估计--Multi-scale Convolutional Neural Networks for Crowd Counting
- shiro系列-shiro是用来干嘛的?
- 事务及转账的例子
- 用angular方法简单实现了吃了么搜索小功能,还不太完善,后续会继续添加新内容。
- Linux---CentOS 定时运行脚本配置
- web.xml 中spring-servlet.xml 和 application.xml 配置位置及含义
- Nettry--技术浅析
- javaMail邮件发送