всей БД, 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?
тебе нужны таблицы в схеме information_scema для получения списка таблиц и колонок. а потом через динамический sql собираешь запросы и пуляешь через exec
Обсуждают сегодня