国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > SQL Server > 正文

mssql 30萬條數據 搜索文本字段的各種方式對比

2020-07-25 13:27:36
字體:
來源:轉載
供稿:網友
數據庫:
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,會更快!
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 安泽县| 阳曲县| 江口县| 华池县| 灵璧县| 施甸县| 望城县| 扶风县| 广南县| 城市| 海晏县| 温泉县| 石楼县| 如东县| 会东县| 陵水| 商丘市| 铜山县| 会宁县| 韶山市| 田阳县| 维西| 宁乡县| 南皮县| 东山县| 宕昌县| 陇西县| 丹巴县| 二手房| 密云县| 松滋市| 古丈县| 永登县| 镇远县| 若尔盖县| 博兴县| 舟曲县| 松阳县| 嵩明县| 邢台市| 堆龙德庆县|