xandeadx.ru Блог музицирующего веб-девелопера

Drupal → Массово скопировать все значения одного поля в другое

Опубликовано в

Сниппет, копирующий все значения поля field_old в field_new:

$field_name_from = 'field_old';
$field_name_to = 'field_new';
 
$field_info = field_info_field($field_name_from);
$value_columns_from = array();
$value_columns_to = array();
foreach ($field_info['columns'] as $column_name => $column_info) {
  $value_columns_from[] = $field_name_from . '_' . $column_name;
  $value_columns_to[] = $field_name_to . '_' . $column_name;
}
foreach (array('data', 'revision') as $table) {
  db_query("
    INSERT INTO field_{$table}_{$field_name_to} (entity_type, bundle, deleted, entity_id, revision_id, language, delta, " . implode(', ', $value_columns_to) . ")
    SELECT entity_type, bundle, deleted, entity_id, revision_id, language, delta, " . implode(', ', $value_columns_from) . " FROM field_{$table}_{$field_name_from}
  ");
}
cache_clear_all('*', 'cache_field', TRUE);

Тип полей должен быть одинаковый. Не будет работать с полями, которые хранят данные не в field_data_* таблицах, например таксономия и файлы.

Решить задачу можно и из админки, с помощью VBO.

Похожие записи

Комментарии RSS

Скажите, а как массово скопировать так же значения из SKU Drupal Commerce в моё поле Product Display?

А есть ли вариант как изменить тип поля или аналогично скопировать значения одного поля в другое разного типа? В частности для изменения поля типа "Entity Reference" на тип "Ссылка на термин"?

Заранее благодарю за ответ

Оставить комментарий

Содержимое этого поля является приватным и не будет отображаться публично. Если у вас есть аккаунт в Gravatar, привязанный к этому e-mail адресу, то он будет использован для отображения аватара.
  • Адреса страниц и электронной почты автоматически преобразуются в ссылки.
  • Доступные HTML теги: <a> <i> <b> <strong> <code> <ul> <ol> <li> <blockquote> <em> <s>
  • Строки и параграфы переносятся автоматически.
  • Подсветка кода осуществляется с помощью тегов: <code>, <css>, <html>, <ini>, <javascript>, <sql>, <php>. Поддерживаемые стили выделения кода: <foo>, [foo].

Подробнее о форматировании