Hibernate导出到csv

时间:2015-04-04 06:37:00

标签: mysql hibernate hql export-to-excel export-to-csv

我想将查询结果导出到excel或csv文件。 我正在使用hibernate struts。 是否有像outfile这样的查询'哪个可以直接导出excel到指定位置? 在MySQL数据库中,'进入outfile'查询工作正常但在休眠时它不起作用。 我尝试使用原生sql,但它提供了错误,无法执行批量操作查询'无论如何我无法解决这个问题。 我正在使用MySQL数据库。

1 个答案:

答案 0 :(得分:2)

如果您正在编写Web应用程序并使用spring,则可以通过将数据写入输出流

来实现

编写一个简单的类来构建您的响应

public class CsvResponse {    
   private final String filename;
   private final List<YourPojo> records;

   public CsvResponse(List<YourPojo> records, String filename) {
       this.records = records;
       this.filename = filename;
   }
   public String getFilename() {
       return filename;
   }
   public List<YourPojo> getRecords() {
       return records;
   }
}

现在编写一个消息转换器将它们写入输出流

public class CsvMessageConverter extends AbstractHttpMessageConverter<CsvResponse> {
   public static final MediaType MEDIA_TYPE = new MediaType("text", "csv", Charset.forName("UTF-8"));
   public CsvMessageConverter() {
       super(MEDIA_TYPE);
   }

   protected boolean supports(Class<?> clazz) {
       return CsvResponse.class.equals(clazz);
   }

   protected void writeInternal(CsvResponse response, HttpOutputMessage output) throws Exception {
       output.getHeaders().setContentType(MEDIA_TYPE);
       output.getHeaders().set("Content-Disposition", "attachment; filename=\"" + response.getFilename() + "\"");
       OutputStream out = output.getBody();

       CsvWriter writer = new CsvWriter(new OutputStreamWriter(out), '\u0009');
       List<YourPojo> allRecords = response.getRecords();
       for (int i = 1; i < allRecords.size(); i++) {
            YourPojo aReq = allRecords.get(i);
            writer.write(aReq.toString());
       }
       writer.close();
   }
}

将此邮件转换器添加到您的应用程序上下文配置文件

<mvc:annotation-driven>
    <mvc:message-converters register-defaults="true">
        <bean class="com.yourpackage.CsvMessageConverter"/>
    </mvc:message-converters>
</mvc:annotation-driven>

最后控制器看起来像

@RequestMapping(value = "/csvData", method = RequestMethod.GET, produces="text/csv")
@ResponseBody
public CsvResponse getFullData(HttpSession session) throws IOException {
      // get data
      List<YourPojo> allRecords = yourService.getData();

      return new CsvResponse(allRecords, "yourData.csv");
}

我发现了使用JAX RS here的类似方式。

但是底线是你必须使用 REST机制将数据输入到输出流中,如果你想以正确的方式进行,但如果你唯一的目标是将数据输入到输出流中文件,您只需将数据放入列表中,然后将其写入文件即可。