Есть ли какой-нибудь способ для DBUnit автоматически создавать таблицы?
-
20-09-2019 - |
Вопрос
Я только что понял, что DBUnit не создает таблицы сам по себе (см. Как мне протестировать DBUnit с простым JDBC и HSQLDB, не сталкиваясь с исключением NoSuchTableException?).
Есть ли какой-либо способ для DBUnit автоматически создавать таблицы из dataset или 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";
}
Решение
Не совсем.Как указывает ответ, на который вы ссылаетесь, XML-файлы dbunit содержат данные, но не типы столбцов.
И вы действительно не хотите этого делать; вы рискуете загрязнить свою базу данных артефактами тестирования, открывая возможность того, что рабочий код случайно будет использовать таблицы, созданные в процессе тестирования.
Необходимость сделать это настоятельно предполагает, что у вас нет адекватного определения и сценария процесса создания и обслуживания базы данных.
Другие советы
Нет.Вам придется выполнить сценарий SQL с определениями таблиц.
Как я писал в другой теме, XML не содержит достаточно данных для создания таблицы.Я думаю, вы могли бы сделать что-то страшное, например проанализировать значения, чтобы попытаться выяснить, какие значения они содержат, но это было бы довольно хрупко.Он отличается от Hibernate тем, что аннотированные классы содержат много информации о том, как выглядит база данных.Часть в аннотациях и часть в полях типов Java.
Spring Boot / Spring JDBC может инициализировать базу данных с помощью обычного JDBC.
Spring JDBC имеет функцию инициализатора источника данных.Spring Boot включает это по умолчанию и загружает SQL из стандартных расположений
schema.sql
иdata.sql
(в корневом каталоге classpath).Кроме того, пружинный ботинок будет загружатьschema-${platform}.sql
иdata-${platform}.sql
файлы (если присутствуют), где platform - значениеspring.datasource.platform
, напримервы можете установить его в качестве имени поставщика базы данных (hsqldb, h2, oracle, mysql, postgresql и т.д.).
https://docs.spring.io/spring-boot/docs/current/reference/html/howto-database-initialization.html
Если вы используете JPA, вы обычно можете настроить своего поставщика JPA так, чтобы он создавал/обновлял таблицы при инициализации.
Например.для спящего режима укажите свойство hibernate.hbm2ddl.auto и установите для него значение create-drop (для тестирования должно подойти).
Смотрите также: Документация Hibernate, глава 3. Настройка.
Однако убедитесь, что поставщик JPA первым обращается к БД;)
Я просто хотел присоединиться и сказать, что это было очень полезно для меня.Мне нужно было подключиться к базе данных Oracle и экспортировать ее в XML-файл, затем импортировать ее как тестовую базу данных HSQL и получить к ней доступ с помощью Hibernate.Я использовал этот код для создания таблиц перед выполнением
DatabaseOperation.CLEAN_INSERT.execute(conn, dataset);.
Однако следует предостеречь: этот код устанавливает первый столбец каждой таблицы в качестве первичного ключа, поэтому будьте осторожны, если вы используете таблицы отношений, поскольку при импорте вы можете получить «нарушение ограничения первичного ключа».Спасибо за фрагмент кода!