Есть ли способ DBUnit для автоматического создания таблиц?
Я просто понял, что DBUnit не создает таблицы сам по себе (см. Как я могу протестировать с помощью DBUnit с помощью простых JDBC и HSQLDB, не сталкиваясь с NoSuchTableException?).
Есть ли способ DBUnit для автоматического создания таблиц из набора данных или dtd?
EDIT: Для простого тестирования базы данных в памяти, такой как 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";
}
Ответы
Ответ 1
Не совсем. Поскольку ответ, который вы указали, указывает, что файлы dbunit xml содержат данные, но не типы столбцов.
И вы действительно не хотите этого делать; вы рискуете загрязнить вашу базу данных тестовыми артефактами, открыв возможность того, что производственный код будет случайно опираться на таблицы, созданные в процессе тестирования.
Необходимость сделать это настоятельно говорит о том, что у вас нет надлежащего определения и создания сценария создания и обслуживания db.
Ответ 2
Нет. Вам нужно будет выполнить SQL script с определениями таблиц в.
Как я писал в другом потоке, XML не содержит достаточно данных для создания таблицы. Я думаю, вы могли бы сделать что-то страшное, как разобрать значения, чтобы попытаться определить, какие значения он содержит, но это будет довольно хрупким. Это отличается от Hibernate тем, что в аннотированных классах содержится много информации о том, как выглядит база данных. В аннотациях и части в полях типов Java есть часть.
http://www.dbunit.org/faq.html#ddl
Ответ 3
Spring Загрузка / Spring JDBC может инициализировать базу данных с помощью простого JDBC.
Spring JDBC имеет функцию инициализатора DataSource. Spring Загрузка позволяет по умолчанию и загружает SQL из стандартных местоположений schema.sql
и data.sql
(в корне пути к классам). Кроме того, Spring Boot будет загрузите файлы schema-${platform}.sql
и data-${platform}.sql
(если present), где платформа - это значение spring.datasource.platform
, например вы можете выбрать его для имени поставщика базы данных (hsqldb, h2, oracle, mysql, postgresql и т.д.).
https://docs.spring.io/spring-boot/docs/current/reference/html/howto-database-initialization.html
Ответ 4
Если вы используете JPA, вы обычно можете настроить своего поставщика JPA, чтобы он создавал/обновлял таблицы при инициализации.
например. для hibernate укажите свойство hibernate.hbm2ddl.auto и установите его значение в create-drop (должно быть хорошо для тестирования).
Смотрите также: Hibernate Documentation, глава 3 Конфигурация
Однако убедитесь, что поставщик JPA первым обратился к БД;)
Ответ 5
Я просто хотел перезвонить и сказать, что это очень полезно для меня. Мне нужно было подключиться к базе данных Oracle и экспортировать его в XML файл, а затем импортировать его как тестовую базу данных HSQL и получить доступ к ней с помощью Hibernate. Я использовал этот код для создания таблиц перед тем, как делать
DatabaseOperation.CLEAN_INSERT.execute(conn, dataset);.
Слово предостережения, хотя этот код устанавливает первый столбец каждой таблицы в качестве первичного ключа, поэтому будьте осторожны, если вы используете таблицы отношений, так как вы можете получить "нарушение ограничения первичного ключа" при импорте. Спасибо за фрагмент кода!