掃二維碼與項目經(jīng)理溝通
我們在微信上24小時期待你的聲音
解答本文疑問/技術咨詢/運營咨詢/技術建議/互聯(lián)網(wǎng)交流
數(shù)據(jù)庫:

成都創(chuàng)新互聯(lián)公司專業(yè)為企業(yè)提供博野網(wǎng)站建設、博野做網(wǎng)站、博野網(wǎng)站設計、博野網(wǎng)站制作等企業(yè)網(wǎng)站建設、網(wǎng)頁設計與制作、博野企業(yè)網(wǎng)站模板建站服務,10余年博野做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡服務。
30萬條,有ID列但無主鍵,在要搜索的“分類”字段上建有非聚集索引
過程T-SQL:
/*
用戶自定義函數(shù):執(zhí)行時間在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 '%醫(yī)學%' --“分類”列有非聚集索引,比聚集索引1150快一點,差不多執(zhí)行時間在1100左右
-- select 書名 from gethl('醫(yī)學') --使用用戶自定義函數(shù),效率和建立聚集索引一樣,還稍慢一點 在1150-1200
-- Execute getfl '醫(yī)學' --調(diào)用存儲過程不能用括號包含參數(shù) Execute getfl('醫(yī)學')
-- select 書名 from VIEW1 --視圖
print '運行時間:
print datediff(ms,@a,getDate())
結論:
1、以上各種使用直接查詢、函數(shù)、視圖、存儲過程性能都差不多;
2、在這種文本字段,非聚集比聚集索引效果好。
比這些更好的方法是,在另外一個表上建立相應的檢索ID,會更快!大家可以根據(jù)自己的情況,選擇一種適合自身的方式,希望上文中講到的內(nèi)容對大家能夠有所幫助。

我們在微信上24小時期待你的聲音
解答本文疑問/技術咨詢/運營咨詢/技術建議/互聯(lián)網(wǎng)交流