Мой вопрос в том, что у меня есть такая строка
Red,House|White,Car|Blue,Table
и я хочу вставить эти элементы в разные строки, подобные этому
- Col1 Col2
- -----------
- Red House
- White Car
- Blue Table
Как мне это сделать?
Вы можете попробовать этот запрос.
DECLARE @str VARCHAR(500) = 'Red,House|White,Car|Blue,Table'
CREATE TABLE #Temp (tDay VARCHAR(100))
WHILE LEN(@str) > 0
BEGIN
DECLARE @TDay VARCHAR(100)
IF CHARINDEX('|',@str) > 0
SET @TDay = SUBSTRING(@str,0,CHARINDEX('|',@str))
ELSE
BEGIN
SET @TDay = @str
SET @str = ''
END
INSERT INTO #Temp VALUES (@TDay)
SET @str = REPLACE(@str,@TDay + '|' , '')
END
SELECT *
FROM #temp
SELECT tday,
PARSENAME(REPLACE(tday,',','.'),2) 'Col1' ,
PARSENAME(REPLACE(tday,',','.'),1) 'Col2'
FROM #temp
Вы можете проверить живую демонстрацию Здесь.
может быть, это то, что вы ищете.
SELECT Substring(value, 1,Charindex(',', value)-1) as col1
, Substring(value, Charindex(',', value)+1, LEN(value)) as col2
FROM STRING_SPLIT('Red,House|White,Car|Blue,Table', '|')
работает с SQL Server 2016
Я использую string_split()
или аналогичную функцию разделения строк, которую вы можете добавить в свою базу данных. Тем не менее, я бы сформулировал окончательную логику извлечения следующим образом:
select left(s.value, v.split - 1),
stuff(s.value, 1, v.split, '')
from string_split('Red,House|White,Car|Blue,Table', '|') s cross apply
(values (charindex(',', s.value))) v(split);