原文:
SQL表值函數和標量值函數的區別
?
?
?
?
這個函數的主要功能就是返回當前節點下的所有子節點,在存儲過程中寫select * from testGetSubNodes(nodeId)就可以返回表中的數據了。再寫一個標量值函數
?
?
?
?
這個函數很簡單返回一個整型值,然后就可以在存儲過程中調用了,不過調用的方式有所不同,象上面的表值函數調用是不需要所有者的,只要寫函數名稱就可以,對于標量值函數來說,是需要加上所有者的,比如所有者是dboselect dbo.testGetSubNodes_,這樣就可以返回5,如果不加dbo,那sql會不認識這個函數。
?
-
?
? ? -
ALTER
?
FUNCTION ? testGetSubNodes? ? -
(?
? -
?
? ? ? @nodeId? int ? ? -
)?
? -
RETURNS
?
@t? TABLE ? ? ? -
(?
? -
?
? ? ? id? bigint ? identity(1,1)? not ? null ,? ? ? -
?
? ? ? nodeIds? int ,? ? -
?
? ? ? nodeName? varchar (500)? ? -
)?
? -
AS
?
? -
BEGIN
?
? -
?
? ? ? insert ? into ? @t? values (@nodeId, 'header' );? ? ? -
?
? ? ? while? exists( select ? nodeid? from ? dbo.Tree? where ? parentid? in ? ( select ? nodeIds? from ? @t)? and ? nodeid? not ? in ( select ? nodeIds? from ? @t))? ? -
?
? ? ? begin ? ? -
?
? ? ? ? ? ? ? insert ? into ? @t? select ? nodeid,? nodename? from ? dbo.Tree? where ? parentid? in ? ( select ? nodeIds? from ? @t)? ? -
?
? ? ? end ? ? ? -
?
? ? ? RETURN ? ? ? -
END
?
?
-
?
ALTER ? FUNCTION ? [dbo].[testGetSubNodes_]? ? -
(?
? -
?
? ? ? @nodeId? int ? ? -
)?
? -
RETURNS
?
int ? ? -
AS
?
? -
BEGIN
?
? -
?
? ? ? declare ? @nodeCount? int ? ? -
?
? ? ? select ? @nodeCount=5? from ? MenuTree? ? -
?
? ? ? return ? @nodeCount? ? -
END
?
?
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
