Tôi vừa nhận ra rằng DBUnit không tự tạo bảng (xem How do I test with DBUnit with plain JDBC and HSQLDB without facing a NoSuchTableException?).Có cách nào để DBUnit tự động tạo bảng không?
Có cách nào để DBUnit tự động tạo bảng từ tập dữ liệu hoặc dtd không?
EDIT: Để thử nghiệm đơn giản của một cơ sở dữ liệu trong bộ nhớ như HSQLDB, một cách tiếp cận thô có thể được sử dụng để tự động tạo bảng:
private void createHsqldbTables(IDataSet dataSet, Connection connection) throws DataSetException, SQLException {
String[] tableNames = dataSet.getTableNames();
String sql = "";
for (String tableName : tableNames) {
ITable table = dataSet.getTable(tableName);
ITableMetaData metadata = table.getTableMetaData();
Column[] columns = metadata.getColumns();
sql += "create table " + tableName + "(";
boolean first = true;
for (Column column : columns) {
if (!first) {
sql += ", ";
}
String columnName = column.getColumnName();
String type = resolveType((String) table.getValue(0, columnName));
sql += columnName + " " + type;
if (first) {
sql += " primary key";
first = false;
}
}
sql += "); ";
}
PreparedStatement pp = connection.prepareStatement(sql);
pp.executeUpdate();
}
private String resolveType(String str) {
try {
if (new Double(str).toString().equals(str)) {
return "double";
}
if (new Integer(str).toString().equals(str)) {
return "int";
}
} catch (Exception e) {}
return "varchar";
}
này không tạo ra bất kỳ bảng, mã chỉ chèn dữ liệu từ các tập dữ liệu được cung cấp. – tak3shi