WordPress как на ладони
Новые WordPress шаблоны Недорогой хостинг для сайтов на WordPress: wordpress.jino.ru

wp search-replace

Поиск/замена строк в базе данных.

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

По умолчанию команда использует таблицы, зарегистрированные в объекте $wpdb. На multisite это будут только таблицы для текущего сайта, если не указан параметр --network.

Поиск/замена интеллектуально обрабатывает сериализованные данные PHP и не изменяет значения первичного ключа.

Использование

wp search-replace {old} {new} [{table}...] [--dry-run] [--network] [--all-tables-with-prefix] [--all-tables] [--export[={file}]] [--export_insert_size={rows}] [--skip-tables={tables}] [--skip-columns={columns}] [--include-columns={columns}] [--precise] [--recurse-objects] [--verbose] [--regex] [--regex-flags={regex-flags}] [--regex-delimiter={regex-delimiter}] [--regex-limit={regex-limit}] [--format={format}] [--report] [--report-changed-only] [--log[={file}]] [--before_context={num}] [--after_context={num}]

Можно указать Глобальные параметры и следующие:

{old}
Строка для поиска в базе данных.
{new}
Строка на которую нужно заменить найденную строку.
[{table}...]
Список таблиц базы данных в которых нужно проводить поиск. Поддерживаются подстановочные знаки, например 'wp_*options' или 'wp_post*'.
[--dry-run]
Выполнить всю операцию поиска/замены и показать отчет, но реально не производить замену в базе данных.
[--network]
Поиск/замена по всем таблицам, зарегистрированным в $wpdb в multisite установке.
[--all-tables-with-prefix]
Включите замену для любых таблиц, соответствующих префиксу таблиц, даже если они не зарегистрированы в $wpdb.
[--all-tables]
Включите замену для всех таблиц в базе данных, независимо от префикса, и их регистрации в $wpdb. Переписывает опции --network и --all-tables-with-prefix.
[--export[={file}]]
Записать преобразованные данные в SQL файл, не сохранять изменения в БД. Если {file} не указан, выводится в стандартный вывод (STDOUT).
[--export_insert_size={rows}]
Определяет количество строк в одном операторе INSERT при выполнении экспорта SQL. Возможно этот параметр нужно изменить если того требует конфигурация базы данных (например, если вам нужно сделать меньше запросов).
По умолчанию: 50
[--skip-tables={tables}]
Не выполнять замену в указанных таблицах. Используйте запятые для указания нескольких таблиц.
[--skip-columns={columns}]
Не выполняйте замену в указанных колонках таблиц. Используйте запятые для указания нескольких столбцов.
[--include-columns={columns}]
Выполнять замену для определенных столбцов. Используйте запятые для указания нескольких столбцов.
[--precise]
Принудительное использование PHP варианта запроса (вместо SQL). PHP является более точным, но при этом более медленным.
[--recurse-objects]
Включить рекурсию в объекты для замены строк. Укажите --no-recurse-objects для отключения.
По умолчанию: true
[--verbose]
Выводит строки в консоль по мере их обновления.
[--regex]
Выполняет поиск с помощью регулярного выражения (без разделителей).
Заметка: с --regex работает в 15-20 раз медленее.
[--regex-flags={regex-flags}]
Модификаторы PCRE для --regex (например, 'i' для нечувствительности к регистру).
[--regex-delimiter={regex-delimiter}]
Разделитель, используемый для регулярного выражения. Он должен быть экранирован, если он появляется в строке regex.
По умолчанию: результат chr(1)
[--regex-limit={regex-limit}]
Максимальное количество возможных замен для регулярного выражения. При десириализации влияет на каждое значение строки массива.
По умолчанию: -1 (без ограничений)
[--format={format}]
Формат вывода результата. Может быть: table, count.
По умолчанию: table
[--report]
Составить отчет.
По умолчанию: true
[--report-changed-only]
Отчитаться только по измененным полям.
По умолчанию: false (есил включено логирование то true)
[--log[={file}]]
Файл для записи логов. Если {file} не указан или в нем указано -, то выводится в STDOUT.
Заметка: замедляет работу, аналогично или хуже включению --precise или `--regex'.
[--before_context={num}]
Сколкьо символов выводить перед старым совпадением и новой заменой. Игнорируется, если лог отключен.
По умолчанию: 40
[--after_context={num}]
Сколкьо символов выводить после старого совпадения и новой заменой. Игнорируется, если лог отключен.
По умолчанию: 40

Примеры

# Search and replace but skip one column
$ wp search-replace 'http://example.dev' 'http://example.com' --skip-columns=guid
# Run search/replace operation but dont save in database
$ wp search-replace 'foo' 'bar' wp_posts wp_postmeta wp_terms --dry-run
# Run case-insensitive regex search/replace operation (slow)
$ wp search-replace '\[foo id="([0-9]+)"' '[bar id="\1"' --regex --regex-flags='i'
# Turn your production multisite database into a local dev database
$ wp search-replace --url=example.com example.com example.dev 'wp_*options' wp_blogs
# Search/replace to a SQL file without transforming the database
$ wp search-replace foo bar --export=database.sql
# Bash script: Search/replace production to development url (multisite compatible)
#!/bin/bash
if $(wp --url=http://example.com core is-installed --network); then
	wp search-replace --url=http://example.com 'http://example.com' 'http://example.dev' --recurse-objects --network --skip-columns=guid --skip-tables=wp_users
else
	wp search-replace 'http://example.com' 'http://example.dev' --recurse-objects --skip-columns=guid --skip-tables=wp_users
fi

WP CLI поиск и замена URL для WordPress multisite

wp search-replace site.ru newsite.ru --precise --network

Исходный код команды

Комментариев нет
    Здравствуйте, !     Войти . Зарегистрироваться