Обновите, чтобы изменить только левую часть значения поля

У меня есть таблица, содержащая (виртуальный) путь к файлу. В поле пути вы можете увидеть такие данные, как:

path
====
folder1
folder2
folder1/111
folder1/111/abc
folder1/111/abc/xyz
folder1/222

Если пользователь хочет переместить папку «111» (расположенную в папке 1) в папку 2, он должен переместить и себя, и любые вложенные папки (abc и xyz). Итак, результаты, которые я ожидаю увидеть, следующие:

path
====
folder1
folder2
folder2/111
folder2/111/abc
folder2/111/abc/xyz
folder1/222

Я не смог придумать способ указать конкретно левую часть строки с помощью функции REPLACE(), но придумал это:

update table set path = replace(path, 'folder1/', 'folder2/')
where path like 'folder1/111/%';

Символ процента, находящийся только справа, изменяет только строки, начинающиеся с «folder1/111/». Однако у меня есть одна проблема, связанная с этим, если бы путь был таким:

folder1/111/folder1/abc

Тогда функция замены заменит оба экземпляра folder1 на folder2.

Примечание. Я буду использовать PHP для создания запроса mysql, поэтому подумал об использовании функции LEFT(). Тем не менее, я чувствую, что мне все еще чего-то не хватает при таком подходе.

Как я могу эффективно выполнять этот поиск и замену, заменяя только текст, который отображается в левой части поля?

Обновлять

Основываясь на одном из ответов ниже, я придумал что-то близкое:

update Test as t,
    (select insert(path, locate('folder1', path), char_length('folder1'), 'folder2') as path from Test) as ins
     set t.path = ins.path
     where LEFT(t.path, 10) = 'folder1/111';

Смотрите мой SQLFiddle.

Моя проблема, однако, заключается в том, что заменяется весь путь на «folder2», а не только часть пути.

Что я делаю неправильно?

Стоит ли изучать PHP в 2023-2024 годах?
Стоит ли изучать PHP в 2023-2024 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
2
0
65
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

update table path = replace(path, 'folder1', 'folder2') 
where path like 'folder1/111%'

Это по-прежнему заменит несколько вхождений папки1, если они появятся в одной строке.

kojow7 09.04.2019 07:38
Ответ принят как подходящий

Если LEFT() не дает вам результата, вы можете попробовать другие функции String, чтобы получить тот же результат.

select path,INSERT(path, LOCATE('folder1', path), CHAR_LENGTH('folder1'), 'folder2')
from yourtable;

Я дал запрос select. Вы можете использовать свой update соответственно.

Рабочий пример: SQLFIDDLE

Ссылка на документы: НАЙТИ(), ВСТАВЛЯТЬ(), CHAR_LENGTH()

Кому UPDATE

update Test set path = INSERT(path, LOCATE('folder1', path), CHAR_LENGTH('folder1'), 'folder2')
where path like 'folder1/111/%';

Рабочий пример: Для обновления

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

kojow7 09.04.2019 19:42

Спасибо, единственная проблема, с которой я столкнулся, заключалась в том, что не работало перемещение папок в корневой каталог или из него. Я думаю, что рефакторинг того, как пути хранятся в базе данных, всегда используя косую черту в конце, исправляет это. Мне просто нужно выяснить, как реорганизовать мой PHP-код.

kojow7 10.04.2019 18:23

Спасибо за помощь. Справочные руководства, которые вы предоставили, были весьма полезны, как и другой сайт, который вы разместили, чтобы компенсировать неработоспособность sqlfiddle.

kojow7 10.04.2019 18:25

Добро пожаловать :). Рад, что смог помочь!

Arun Palanisamy 11.04.2019 07:58

Другие вопросы по теме