Мне нужно реализовать простой поиск в маленькой таблице содержимого: идентификатор, имя, описание, содержимое.
Результаты должны быть отсортированы по приоритетам
- имя
- описание
- содержание
это означает, что если искомое слово было найдено в поле описания, оно будет показано только после всех строк, в которых есть собака в поле имени
Что я сделал:
Я попытался создать временную таблицу со структурой, подобной используемой мной таблице, но с другим приоритетом поля. для каждого поля, которое я использую для поиска, сделайте вставьте select в таблицу temp
* * Пример тысячи двадцать-одина: * ** 1023 тысячу двадцать две *
DECLARE @query NVARCHAR(255)
CREATE TABLE #tbl_search
(
[id] INT NOT NULL ,
[name] NVARCHAR(255) ,
[description] NVARCHAR(MAX) ,
[content] NVARCHAR(MAX) ,
[priority] INT
)
--searching in name field
INSERT INTO #tbl_search
( [ID] ,
[name] ,
[description] ,
[content] ,
[priority]
)
SELECT [ID] ,
[name] ,
[description] ,
[content] ,
1
FROM [tbl_content]
WHERE name LIKE '%' + @query + '%'
--searching in description field
INSERT INTO #tbl_search
( [ID] ,
[name] ,
[description] ,
[content] ,
[priority]
)
SELECT [ID] ,
[name] ,
[description] ,
[content] ,
2
FROM [tbl_content]
WHERE description LIKE '%' + @query + '%'
AND id NOT IN ( SELECT id
FROM #tbl_search )
--.....
SELECT *
FROM #tbl_search
ORDER BY [priority]
DROP TABLE #tbl_search