powered by simpleCommunicator - 2.0.61     © 2026 Programmizd 02
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Форумы / MySQL [игнор отключен] [закрыт для гостей] / Редактирование поля типа set: получение индекса элемента множества
2 сообщений из 2, страница 1 из 1
Редактирование поля типа set: получение индекса элемента множества
    #39205408
A-MaR
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Есть таблица t1, содержащая поле set_field set ('A', 'B', 'C', 'D') . Требуется удалить из всех строк элемент 'C'. Можно конечно решить задачу "в лоб":
Код: sql
1.
2.
3.
4.
5.
UPDATE t1 SET set_field =
  CASE
    WHEN FIND_IN_SET('C', set_field) > 0 THEN set_field - 4
    ELSE set_field
  END


Очень не нравится использование абсолютного индекса элемента 4: если когда-то потребуется удалить из списка возможных значений A или B, то этот индекс изменится, и придется переписывать хренову тучу процедур. Можно конечно сделать select из information_schema.COLUMNS и разобрать значение поля COLUMN_TYPE, но может есть более прямолинейный способ получить индекс нужного элемента (хотя бы только сам список в чистом виде, вместо "set(...)")?
...
Рейтинг: 0 / 0
Редактирование поля типа set: получение индекса элемента множества
    #39205416
A-MaR
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Вопрос снимается: через information_schema.COLUMNS оказался вполне себе ничего способ.
...
Рейтинг: 0 / 0
2 сообщений из 2, страница 1 из 1
Форумы / MySQL [игнор отключен] [закрыт для гостей] / Редактирование поля типа set: получение индекса элемента множества
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]