Что-то вроде этого, возможно?
DECLARE @text NVARCHAR(400) = 'this is a cat'
DECLARE @search NVARCHAR(400) = 'a cat'
SELECT t.value
FROM STRING_SPLIT(@text, ' ') t
join STRING_SPLIT(@search, ' ') s
on t.value = s.value
WHERE RTRIM(t.value) <> '' and RTRIM(s.value) <> '';
Тогда вы можете сравнить, если счетчик этого результата и ваш разделенный поисковый счетчик равны .
Вам понадобится Sql-сервер 2016 или выше, чтобы STRING_SPLIT
заработал.
В случае более низких версий sql вам потребуется создать UDF для разбиения строки. Один такой:
CREATE FUNCTION dbo.fnSplit(
@sInputList VARCHAR(8000) -- List of delimited items
, @sDelimiter VARCHAR(8000) = ',' -- delimiter that separates items
) RETURNS @List TABLE (item VARCHAR(8000))
BEGIN
DECLARE @sItem VARCHAR(8000)
WHILE CHARINDEX(@sDelimiter,@sInputList,0) <> 0
BEGIN
SELECT
@sItem=RTRIM(LTRIM(SUBSTRING(@sInputList,1,CHARINDEX(@sDelimiter,@sInputList,0)-1))),
@sInputList=RTRIM(LTRIM(SUBSTRING(@sInputList,CHARINDEX(@sDelimiter,@sInputList,0)+LEN(@sDelimiter),LEN(@sInputList))))
IF LEN(@sItem) > 0
INSERT INTO @List SELECT @sItem
END
IF LEN(@sInputList) > 0
INSERT INTO @List SELECT @sInputList -- Put the last item in
RETURN
END
GO
И вышеупомянутый запрос становится:
DECLARE @text NVARCHAR(400) = 'this is a cat'
DECLARE @search NVARCHAR(400) = 'a cat'
SELECT t.Item
FROM fnSplit(@text, ' ') t
join fnSplit(@search, ' ') s
on t.Item = s.Item