我已使用ddlUtils成功导出了Derby架构但是如何在derby中导出表数据以插入SQL语句?
答案 0 :(得分:1)
如果您愿意使用第三方工具,可以使用jOOQ
public class ExportAsInsert {
public static void main(String[] args) {
try (DSLContext ctx = DSL.using(url, user, password)) {
ctx.meta()
.getSchemas()
.stream()
// Filter out those schemas that you want to export
.filter(schema -> schema.getName().equals("TEST"))
// Get the tables for each schema...
.flatMap(schema -> schema.getTables().stream())
// ... and format their content as INSERT statements.
.forEach(table -> System.out.println(ctx.fetch(table).formatInsert()));
}
}
}
上面有一个known issue,它在insert语句中生成了错误的表名。您可以通过修补输出来解决此问题:
System.out.println(
ctx.fetch(table).formatInsert().replace("UNKNOWN_TABLE", table.getName()));
(免责声明:我为jOOQ背后的公司工作)
答案 1 :(得分:0)
注意:我使用 Netbeans 8.2。