Быстрая замена текста в MySql таблице

Просмотров: 11255Комментарии: 0
ПрограммированиеPHP-MySQL
Быстрая замена текста в MySql таблице

Иногда случается, что нужно в больших таблицах изменить какой-то текст, который встречается очень часто. Если таблица огромная, то это практически не посильная работа для человека, если исправлять каждую строчку. Но посредством SQL запроса это можно легко реализовать за несколько секунд. Весь секрет быстрой замены текста в mysql таблице заключается в использование команды Replace.

Запрос на замену определенного текста в таблице выглядит так:

UPDATE таблица_имя 
SET поле_имя = REPLACE(поле_имя, 'что заменить', 'чем заменить');

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

Пример, в своем шаблоне CMS MaxSite я использовал новое мета-поле для задания изображений к каждому посту, назвал его minipict. Но с выходом новой версии этой замечательно CMS, появилось поле по умолчанию, для задания превью поста - prev.

И с помощью небольших манипуляций в шаблоне, мне осталось изменить все мои записи со значением minipict на prev.

Для этого я изменил выше представленный запрос, на вот такой:

UPDATE mso_meta SET meta_key = REPLACE(meta_key, 'minipict', 'prev');

В результате запроса я изменил это значение сразу в 431 строках.

MySQL Replace

В редких случаях бывает необходимо добавить в конце запроса условие с присутствием индексного поля id, чтобы избежать ошибки. Тогда наш запрос примет следующий вид:

UPDATE mso_meta 
SET meta_key = REPLACE(meta_key, 'minipict', 'prev') 
WHERE meta_id > 0;

Вот так просто решается данная задача, которая порой может занять много времени, если не знать как ее реализовать.

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

grin LOL cheese smile wink smirk rolleyes confused surprised big surprise tongue laugh tongue rolleye tongue wink raspberry blank stare long face ohh grrr gulp oh oh downer red face sick shut eye hmmm mad angry zipper kiss shock cool smile cool smirk cool grin cool hmm cool mad cool cheese vampire snake excaim question

Используйте нормальные имена. Ваш комментарий будет опубликован после проверки.

     

  

Если вы уже зарегистрированы как комментатор или хотите зарегистрироваться, укажите пароль и свой действующий email. При регистрации на указанный адрес придет письмо с кодом активации и ссылкой на ваш персональный аккаунт, где вы сможете изменить свои данные, включая адрес сайта, ник, описание, контакты и т.д., а также подписку на новые комментарии.

(обязательно)