Я использую комбинацию табличной функции, чтобы разбить список на упорядоченный список. И затем возьмите только последний, используя rownumber.
Вот функция. их там много.
create FUNCTION SplitString
(
@Input NVARCHAR(MAX),
@Character CHAR(1)
)
RETURNS @Output TABLE (
ct int
,Item NVARCHAR(1000)
)
AS
BEGIN
DECLARE @StartIndex INT, @EndIndex INT,@ct int =0
SET @StartIndex = 1
IF SUBSTRING(@Input, LEN(@Input) - 1, LEN(@Input)) <> @Character
BEGIN
SET @Input = @Input + @Character
END
WHILE CHARINDEX(@Character, @Input) > 0
BEGIN
SET @EndIndex = CHARINDEX(@Character, @Input)
set @ct=@ct+1
INSERT INTO @Output(Ct,Item)
SELECT @ct,SUBSTRING(@Input, @StartIndex, @EndIndex - 1)
SET @Input = SUBSTRING(@Input, @EndIndex + 1, LEN(@Input))
END
RETURN
END
GO
Это настроено, поэтому у меня есть таблица для использования. Вы должны добавить это для своей таблицы.
declare @t as table(sentence varchar(max))
insert into @t
values
('The brown dog jumped over the fence')
,('This is the final word')
Вот SQL для извлечения последнего слова:
select *
from (
select * ,rn = ROW_NUMBER() over (partition by sentence order by ct desc)
from @t t
cross apply dbo.splitstring(t.sentence,' ')
) a
where rn=1
Результаты:
sentence ct Item rn
The brown dog jumped over the fence 7 fence 1
This is the final word 5 word 1