2009-10-07 2 views
23

Я просто понял, что DBUnit не создает таблицы сам по себе (см. How do I test with DBUnit with plain JDBC and HSQLDB without facing a NoSuchTableException?).Есть ли способ DBUnit для автоматического создания таблиц?

Есть ли какой-либо способ для 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"; 
} 

ответ

15

Не совсем. Поскольку ответ, на который вы ссылаетесь, указывает, что файлы dbunit xml содержат данные, но не типы столбцов.

И вы действительно не хотите этого делать; вы рискуете загрязнить вашу базу данных тестовыми артефактами, открыв возможность того, что производственный код будет случайно опираться на таблицы, созданные в процессе тестирования.

Необходимо сделать это, убедительно, в том, что у вас нет надлежащего определения и создания сценария создания и обслуживания db.

3

Нет, вы должны выполнить скрипт SQL с таблицы в.

Как я писал в другом потоке, XML не содержит достаточного количества данных для создания таблицы. Я думаю, вы могли бы сделать что-то страшное, как разобрать значения, чтобы попытаться определить, какие значения он содержит, но это будет довольно хрупким. Это отличается от Hibernate тем, что в аннотированных классах содержится много информации о том, как выглядит база данных. В аннотациях и части в полях типов Java есть часть.

http://www.dbunit.org/faq.html#ddl

1

Если вы используете JPA, вы обычно можете настроить поставщика JPA так, чтобы он создавал/обновлял таблицы при инициализации.

E.g. для hibernate укажите свойство hibernate.hbm2ddl.auto и установите его значение для создания-падения (должно быть хорошо для тестирования).

Смотрите также: Hibernate Documentation, Chapter 3 Configuration

Однако, убедитесь, что провайдер JPA является первым, чтобы получить доступ к БД;)

0

Я просто хотел, чтобы куранты и сказать, что это было очень полезно для меня. Мне нужно было подключиться к базе данных Oracle и экспортировать его в XML-файл, а затем импортировать его как тестовую базу данных HSQL и получить доступ к ней с помощью Hibernate. Я использовал этот код для создания таблиц, прежде чем делать

DatabaseOperation.CLEAN_INSERT.execute(conn, dataset);. 

слова предостережения, хотя, этот код устанавливает первый столбец каждой таблицы в качестве первичного ключа, так что будьте осторожны, если вы используете таблицы отношений, как вы можете получить «Нарушение ограничения первичного ключа» при импорте. Спасибо за фрагмент кода!

+0

Это не создает каких-либо таблиц, код просто вставляет данные из предоставленного набора данных. – tak3shi

3

Весенняя загрузка/весна JDBC может инициализировать базу данных простым JDBC.

Spring JDBC имеет функцию инициализации источника данных.Spring Boot позволяет по умолчанию и загружает SQL из стандартных местоположений schema.sql и data.sql (в корень пути к классам). Кроме того, Spring Boot будет загрузить schema-${platform}.sql и data-${platform}.sql файлов (если настоящее время), где платформа - это значение spring.datasource.platform, , например. вы можете выбрать его для имени поставщика базы данных (hsqldb, h2, oracle, mysql, postgresql и т. д.).

https://docs.spring.io/spring-boot/docs/current/reference/html/howto-database-initialization.html

Смежные вопросы