我需要将一列中的前半部分单词存储在另一列中。我可以假设有偶数个单词。我使用游标和我发现的一个函数来完成它,该函数接受一个字符串并使用分隔符将其解析为表。
drop table #test
create table #test (id int identity, my_name varchar(128), cleaned_name varchar(128))
insert into #test (my_name) VALUES ('abcd efgh abcd1 efgh1')
insert into #test (my_name) VALUES ('name1 name2 name1a name2a')
insert into #test (my_name) VALUES ('one two one* two*')
select *
from #test
DECLARE @HalfName varchar(100)
DECLARE @i varchar(100)
set @i = 1
while @i <= (select count(*) from #test)
begin
SELECT @HalfName = COALESCE(@HalfName + ' ', '') + aa.WORD
FROM (select top (select count(*) / 2 from dm_generic.dbo.GETALLWORDS((select [my_name]
from #test
where id = @i), ' ')) *
from dm_generic.dbo.GETALLWORDS(
(select [my_name]
from #test
where id = @i), ' ')
) aa
update #test
set cleaned_name = @HalfName
where id = @i
set @i = @i + 1
set @HalfName = ''
end
select *
from #test
我试图在没有光标的情况下做到这一点:
UPDATE bb
SET cleaned_name =
(SELECT COALESCE (bb.cleaned_name + ' ', '') + aa.WORD
FROM (SELECT TOP (SELECT count (*) / 2
FROM dm_generic.dbo.GETALLWORDS (
(SELECT [my_name]
FROM #test a
WHERE a.id = bb.id),
' '))
*
FROM dm_generic.dbo.GETALLWORDS ( (SELECT [my_name]
FROM #test b
WHERE b.id = bb.id),
' ')) aa)
FROM #test bb
我得到的是:
Msg 512, Level 16, State 1, Line 1
Subquery returned more than 1 value. This is not permitted when the subquery follows =, !=, <, <= , >, >= or when the subquery is used as an expression.
The statement has been terminated.
任何帮助将不胜感激。
感谢所有响应者,我终于使用@BradC 的这个解决方案来酿造我自己的解决方案,这里是:
update updated
set cleaned_name = (
SELECT Clean
FROM #test AS extern
CROSS APPLY
(
select TOP (SELECT count (*) / 2
FROM dm_generic.dbo.GETALLWORDS (
(SELECT [my_name]
FROM #test a
WHERE a.id = extern.id), ' '))
WORD + ' '
FROM dm_generic.dbo.GETALLWORDS (
(SELECT [my_name]
FROM #test a
WHERE a.id = extern.id),
' ')
FOR XML PATH('')
) pre_trimmed (Clean)
where extern.id = updated.id)
from #test updated
@Nikola Markovinović 解决方案也很有效。