存儲(chǔ)過(guò)程之SET NOCOUNT ON/OFF 含義
每次我們?cè)谑褂貌樵?xún)分析器調(diào)試SQL語(yǔ)句的時(shí)候,通常會(huì)看到一些信息,提醒我們當(dāng)前有多少個(gè)行受到了影響,這是些什么信息?在我們調(diào)用的時(shí)候這些信息有用嗎?是否可以關(guān)閉呢??
答案是這些信息在我們的客戶端的應(yīng)用程序中是沒(méi)有用的,這些信息是存儲(chǔ)過(guò)程中的每個(gè)語(yǔ)句的DONE_IN_PROC?信息。?
我們可以利用SET?NOCOUNT?來(lái)控制這些信息,以達(dá)到提高程序性能的目的。?
MSDN中幫助如下:?
?
SET?NOCOUNT?
使返回的結(jié)果中不包含有關(guān)受?Transact-SQL?語(yǔ)句影響的行數(shù)的信息。?
語(yǔ)法?
SET?NOCOUNT?{?ON?|?OFF?}?
注釋?
當(dāng)?SET?NOCOUNT?為?ON?時(shí),不返回計(jì)數(shù)(表示受?Transact-SQL?語(yǔ)句影響的行數(shù))。當(dāng)?SET?NOCOUNT?為?OFF?時(shí),返回計(jì)數(shù)。?
即使當(dāng)?SET?NOCOUNT?為?ON?時(shí),也更新?@@ROWCOUNT?函數(shù)。?
當(dāng)?SET?NOCOUNT?為?ON?時(shí),將不給客戶端發(fā)送存儲(chǔ)過(guò)程中的每個(gè)語(yǔ)句的?DONE_IN_PROC?信息。當(dāng)使用?Microsoft?SQL?Server?提供的實(shí)用工具執(zhí)行查詢(xún)時(shí),在?Transact-SQL?語(yǔ)句(如?SELECT、INSERT、?UPDATE?和?DELETE)結(jié)束時(shí)將不會(huì)在查詢(xún)結(jié)果中顯示"nn?rows?affected"。?
如果存儲(chǔ)過(guò)程中包含的一些語(yǔ)句并不返回許多實(shí)際的數(shù)據(jù),則該設(shè)置由于大量減少了網(wǎng)絡(luò)流量,因此可顯著提高性能。?
SET?NOCOUNT?設(shè)置是在執(zhí)行或運(yùn)行時(shí)設(shè)置,而不是在分析時(shí)設(shè)置。?
權(quán)限?
SET?NOCOUNT?權(quán)限默認(rèn)授予所有用戶。?
結(jié)論:我們應(yīng)該在存儲(chǔ)過(guò)程的頭部加上SET?NOCOUNT?ON?這樣的話,在退出存儲(chǔ)過(guò)程的時(shí)候加上?SET?NOCOUNT?OFF這樣的話,以達(dá)到優(yōu)化存儲(chǔ)過(guò)程的目的。