Нужна помощь в написании MySQL запроса Общая задача: заменить URL во

всей БД, URL встечается многократно в разных колонках и в разных таблицах по многу раз.

SET @old_url := 'lalafo.kg';
SET @new_url := 'olx.kz';

# SELECT * FROM wp_wm_trees WHERE tr_title LIKE concat('%', @old_url, '%');
UPDATE wp_wm_trees SET tr_title = replace(tr_title, @old_url, @new_url)
WHERE tr_title LIKE concat('%', @old_url, '%');
☝🏻 заменяет все вхождения внутри одной колонки только одной таблицы.
Соответственно, для другой колонки будет:
# SELECT * FROM wp_wm_trees WHERE tr_link LIKE concat('%', @old_url, '%');
UPDATE wp_wm_trees SET tr_link = replace(tr_link, @old_url, @new_url)
WHERE tr_link LIKE concat('%', @old_url, '%');

Хочу сделать универсальное решение хотя бы в пределах одной таблицы - чтобы скрипт в цикле пробегался по всем указанным колонкам и делал замену.

На php / javascript это будет примерно так:
$columns = ['tr_title', 'tr_link', 'tr_thumbnail_url'];
foreach ($columns as $column) {
...
}
Как это сделать на MySQL? В MySQL нет массивов, да и с циклами нет возможностей так легко циклы обходить, как в случае с foreach.

В идеале хочу, чтобы скрипт процессил всю БД. Примерно с такой логикой:
$toProcess = [
'table_1' => ['tr_title', 'tr_link', 'tr_thumbnail_url'],
'table_2' => ['tr_1', 'tr_2',],
'table_3' => ['tr_first', 'tr_second', 'tr_third'],
...
];
foreach ($toProcess as $table) {
foreach ($table as $column) {
...
}
}
Как это сделать средствами MySQL?

1 ответов

9 просмотров

тебе нужны таблицы в схеме information_scema для получения списка таблиц и колонок. а потом через динамический sql собираешь запросы и пуляешь через exec

Похожие вопросы

Обсуждают сегодня

Но, может, есть уже проверенная? Наши требования такие: 1. Сообщения должны приходить из Инста в CRM оду 2. Должна быть возможность подключить несколько экаунтов Инстаграм. Р...
Alexander Sharoiko MSE / Александр Шаройко
7
Я правильно понимаю что нет способов получить список ожидающих заявок на вступление в группу с помощью бота из mtproto?
Шамиль Прилов
7
Это может быть все-таки не флудвейт? у меня ботфазер принимает изменения и отображает даже что они изменились, на видео видно что он прислал якобы уже измененное описание, н...
OVERLINK
13
Добрый день. Мне посоветовали обратиться к вам в чат за помощью. Ситуация описана на скрине. Как мне сказали, мне на бота навесили флудвейт. Есть ли возможность снять его ра...
OVERLINK
7
всем привет помогите пожалуйста используя CDN (GCP) у игроков из вьетнама загружается конфиг (размер 999 bytes) загружается 5 и более минут н а других CDN сервисах такой пробл...
Andrew Krw.
1
Просто по очереди выпиливаешь на ручной маппинг? По методу за раз
Andrii Kurdiumov
7
Приветствую. А не подскажете какие ограничения есть на использования api метода setMyName ? Несколько раз сменил имя бота и получил бан на 2 месяца на смену имени.
Slick Slack
8
)) может, нужно поправить? )) 2. Ребята, нам нужно, чтобы сообщения из Инстаграм приходили в ОДУ. Какое приложение посоветуете?
Alexander Sharoiko MSE / Александр Шаройко
1
Всем привет! Взялся портировать модули на 18 версию, лезет _logger.log(log_level, 'no translation language detected, skipping translation %s', frame, stack_info=True) А чт...
Max Lit
3
Привет, коллеги! Возникла задача ограничить максимальный размер вложений для определённых расширений, например, чтобы для изображений лимит был 10 МБ, а для видео — 100 МБ. Ог...
Andro
1
Карта сайта