Есть ли способ для DBUnit автоматически создавать таблицы? - PullRequest
23 голосов
/ 07 октября 2009

Я только что понял, что DBUnit не создает таблицы сам по себе (см. Как мне протестировать DBUnit с обычными JDBC и HSQLDB, не сталкиваясь с 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";
}

Ответы [ 5 ]

16 голосов
/ 07 октября 2009

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

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

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

4 голосов
/ 07 октября 2009

Нет. Вам нужно будет выполнить сценарий SQL с определениями таблиц в.

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

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

3 голосов
/ 03 мая 2016

Spring Boot / Spring 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

2 голосов
/ 19 октября 2009

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

например. для hibernate укажите свойство hibernate.hbm2ddl.auto и установите для него значение create-drop (должно подойти для тестирования).

См. Также: Документация Hibernate, Глава 3 Настройка

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

0 голосов
/ 18 марта 2011

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

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

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

...