Как добавить значения по умолчанию в таблицу базы данных, используя chook_install ()?

drupal.stackexchange https://drupal.stackexchange.com/questions/9462

  •  16-10-2019
  •  | 
  •  

Вопрос

Я создаю пользовательский модуль со своей собственной схемой из нескольких таблиц. Эти таблицы должны иметь некоторые значения, предварительно заполненные им для работы модуля (местоположения по умолчанию, выбирать параметры и т. Д.).

Каковы лучшие практики способ вставить значения по умолчанию в эти таблицы во время Hook_install?

Поскольку drupal_write_record недоступен, я могу использовать db_query, но я просто хочу убедиться, что я не нарушаю никаких кардинальных правил, делая это.

Это было полезно?

Решение

Лучший способ сделать это внутри kuke_enable (); В то время, когда крюк вызывает, модуль уже установлен, и схема его базы данных доступна для Drupal, и для drupal_write_record(). Анкет Поскольку крюк вызывается все время, модуль включен, и не только при установке модуля, реализация крюка должна проверить, не добавила ли он эти строки базы данных (например, он должен использовать переменную Drupal, содержащую логическое значение) Анкет

В качестве примера модуля, который использует hook_enable() Для аналогичной цели вы можете проверить forum_enable (), или же php_enable () (который добавляет входной формат «Код PHP»).

function php_enable() {
  $format_exists = (bool) db_query_range('SELECT 1 FROM {filter_format} WHERE name = :name', 0, 1, array(':name' => 'PHP code'))->fetchField();
  // Add a PHP code text format, if it does not exist. Do this only for the
  // first install (or if the format has been manually deleted) as there is no
  // reliable method to identify the format in an uninstall hook or in
  // subsequent clean installs.
  if (!$format_exists) {
    $php_format = array(
      'format' => 'php_code', 
      'name' => 'PHP code',
      // 'Plain text' format is installed with a weight of 10 by default. Use a
      // higher weight here to ensure that this format will not be the default
      // format for anyone. 
      'weight' => 11, 
      'filters' => array(
        // Enable the PHP evaluator filter.
        'php_code' => array(
          'weight' => 0, 
          'status' => 1,
        ),
      ),
    );
    $php_format = (object) $php_format;
    filter_format_save($php_format);

    drupal_set_message(t('A <a href="@php-code">PHP code</a> text format has been created.', array('@php-code' => url('admin/config/content/formats/' . $php_format->format))));
  }
}

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

Другие советы

Я бы пошел db_query / db_insert (D6 / D7) в hook_install ().

Это не считается плохой практикой (и никто никогда не заставляет вас использовать drupal_write_record()).

Люди нередко отключают и повторно устанавливают модули, и в этом случае ваш код в hook_enable() будет стрелять каждый раз. Что не хорошо.

Лицензировано под: CC-BY-SA с атрибуция
Не связан с drupal.stackexchange
scroll top