我想将查询结果导出到excel或csv文件。
我正在使用休眠支柱。
是否有任何查询,例如“ into outfile”,可以直接将excel导出到指定位置?
在MySQL数据库中,“进入文件外”查询工作正常,但在休眠状态下则无法工作。
我尝试使用本机sql,但出现错误“无法执行批量操作查询”,无论如何我都无法解决。
我正在使用MySQL数据库。
最佳答案
如果您正在编写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机制,但是如果您的唯一目标是将数据输入文件,则只需将数据存储在列表中然后只需将其写入文件即可。