You может сделать это с чистым SQL, как этого
SELECT SUBSTRING_INDEX(SUBSTRING_INDEX(t.values, ',', n.n), ',', -1) value
FROM table1 t CROSS JOIN
(
SELECT a.N + b.N * 10 + 1 n
FROM
(SELECT 0 AS N UNION ALL SELECT 1 UNION ALL SELECT 2 UNION ALL SELECT 3 UNION ALL SELECT 4 UNION ALL SELECT 5 UNION ALL SELECT 6 UNION ALL SELECT 7 UNION ALL SELECT 8 UNION ALL SELECT 9) a
,(SELECT 0 AS N UNION ALL SELECT 1 UNION ALL SELECT 2 UNION ALL SELECT 3 UNION ALL SELECT 4 UNION ALL SELECT 5 UNION ALL SELECT 6 UNION ALL SELECT 7 UNION ALL SELECT 8 UNION ALL SELECT 9) b
ORDER BY n
) n
WHERE n.n <= 1 + (LENGTH(t.values) - LENGTH(REPLACE(t.values, ',', '')))
ORDER BY value
Примечание: хитрость заключается в том, чтобы использовать таблицу индикаторных (номера) и очень удобный в этом случае функции MySQL SUBSTRING_INDEX()
. Если вы выполняете много таких запросов (расщепление), вы можете подумать о том, чтобы заполнить и использовать сохраненную таблицу таблиц вместо генерации на лету с подзапросом, как в этом примере. Подзапрос в этом примере генерирует последовательность чисел от 1 до 100, эффективно позволяя вам разделить до 100 значений с разделителями на строку в исходной таблице. Если вам нужно больше или меньше, вы можете легко его отрегулировать.
Выход:
| VALUE |
|----------------|
| somethingA |
| somethingB |
| somethingC |
| somethingElseA |
| somethingElseB |
Вот SQLFiddle демо
Это как запрос может выглядеть с сохраняемым столом учетного
SELECT SUBSTRING_INDEX(SUBSTRING_INDEX(t.values, ',', n.n), ',', -1) value
FROM table1 t CROSS JOIN tally n
WHERE n.n <= 1 + (LENGTH(t.values) - LENGTH(REPLACE(t.values, ',', '')))
ORDER BY value
Вот SQLFiddle демо
задал Gazillion раз на SO: eghttp: //stackoverflow.com/questions/10581772/sql-server-2008-how-to-split-a-comma-separated-value-to-columns , http://stackoverflow.com/questions/13873701/convert-comma-separated-column-value-to-rows –
@MitchWheat - это не ответ на этот вопрос. У них есть определенное количество значений, разделенных запятыми, я этого не делаю. –
Вы ищете чистое SQL-решение или решение на каком-то другом языке, например PHP. –