DBUnit有没有办法自动创建表?

neu*_*242 23 java dbunit dataset create-table

我刚刚意识到DBUnit本身并不创建表(请参阅如何使用纯JDBC和HSQLDB使用DBUnit进行测试而不会遇到NoSuchTableException?).

DBUnit有没有办法从数据集或dtd自动创建表?

编辑: 对于像HSQLDB这样的内存数据库的简单测试,可以使用原始方法自动创建表:

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";
}
Run Code Online (Sandbox Code Playgroud)

tpd*_*pdi 16

并不是的.正如您所链接的答案所指出的那样,dbunit xml文件包含数据,但不包含列类型.

你真的不想这样做; 您冒着使用测试工件污染数据库的风险,这可能会导致生产代码意外地依赖于测试过程创建的表.

需要强烈建议您没有充分定义和编写数据库创建和维护过程.