Решение для SQL Server 2008:
вот таблица:
CREATE TABLE MyTable (id INT, txt VARCHAR(MAX));
вот SQL-запрос:
SELECT sum(case when TSplitted.txt_word = 'searched' then 1 else 0 end) as cnt_searched
, count(*) as cnt_all
FROM MyTable MYT
INNER JOIN Fn_Split(MYT.id,' ',MYT.txt) TSplitted on MYT.id=TSplitted.id
здесь есть табличная функция Fn_Split (@id int, @separator VARCHAR (32), @string VARCHAR (MAX)) (взято из здесь ):
CREATE FUNCTION Fn_Split (@id int, @separator VARCHAR(32), @string VARCHAR(MAX))
RETURNS @t TABLE
(
ret_id INT
,txt_word VARCHAR(MAX)
)
AS
BEGIN
DECLARE @xml XML
SET @XML = N'<root><r>' + REPLACE(@s, @separator, '</r><r>') + '</r></root>'
INSERT INTO @t(ret_id, val)
SELECT @id, r.value('.','VARCHAR(5)') as Item
FROM @xml.nodes('//root/r') AS RECORDS(r)
RETURN
END