如何解决使用Java将Access DB查询数据输出到csv文件
我能够打开数据库文件并获取查询名称和语句。如何将查询数据输出到csv?我以为他在exportWriter下面可以做到,但没有用。
Database db = Database.open(new File(args[0]));
for(Query query : db.getQueries()) {
System.out.println(query.getName() + ": " + query.toSQLString());
if query.getName() = "thequerytooutput" {
BufferedWriter csvOut = new BufferedWriter(new OutputStreamWriter(System.out));
ExportUtil.exportWriter(db,query.getName(),csvOut,true,null,'"',SimpleExportFilter.INSTANCE);
}
}
解决方法
git lg
不运行查询,它仅转储表。您需要提供一个有效的表名作为第二个参数。如here所述,Jackcess无法执行sql查询。
我认为一个更好的选择是先将数据库中的值存储到字符串的“二维”列表中(我假设您知道该怎么做[如果没有,请告诉我,我会澄清更多])。然后使用FileWriter将数组写入CSV文件。
此示例摘自stackabuse.com
List<List<String>> rows = Arrays.asList(
Arrays.asList("Jean","author","Java"),Arrays.asList("David","editor","Python"),Arrays.asList("Scott","Node.js")
);
FileWriter csvWriter = new FileWriter("new.csv");
csvWriter.append("Name");
csvWriter.append(",");
csvWriter.append("Role");
csvWriter.append(",");
csvWriter.append("Topic");
csvWriter.append("\n");
for (List<String> rowData : rows) {
csvWriter.append(String.join(",",rowData));
csvWriter.append("\n");
}
csvWriter.flush();
csvWriter.close();
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。