mssql 30萬條數據 搜刮文本字段的各類方法比較。本站提示廣大學習愛好者:(mssql 30萬條數據 搜刮文本字段的各類方法比較)文章只能為提供參考,不一定能成為您想要的結果。以下是mssql 30萬條數據 搜刮文本字段的各類方法比較正文
數據庫:
30萬條,有ID列但無主鍵,在要搜刮的“分類”字段上建有非集合索引
進程T-SQL:
/*
用戶自界說函數:履行時光在1150-1200毫秒閣下
CREATE FUNCTION [dbo].[gethl] (@types nvarchar(4))
RETURNS table AS
return select 書名 from 圖書三十萬條 Where 分類 Like '%'+@types+'%'
存儲進程:
CREATE PROCEDURE [dbo].[getfl](@typen nvarchar(4))
AS
select 書名 from 圖書三十萬條 Where 分類 Like '%'+@typen+'%'
*/
declare @a datetime,@b nvarchar(4)
set @a=getDate()
select 書名 from 圖書三十萬條 Where 分類 Like '%醫學%' --“分類”列有非集合索引,比集合索引1150快一點,差不多履行時光在1100閣下
-- select 書名 from gethl('醫學') --應用用戶自界說函數,效力和樹立集合索引一樣,還稍慢一點 在1150-1200
-- Execute getfl '醫學' --挪用存儲進程不克不及用括號包括參數 Execute getfl('醫學')
-- select 書名 from VIEW1 --視圖
print '運轉時光:
print datediff(ms,@a,getDate())
結論:
1、以上各類應用直接查詢、函數、視圖、存儲進程機能都差不多;
2、在這類文本字段,非集合比集合索引後果好。
比這些更好的辦法是,在別的一個表上樹立響應的檢索ID,會更快!