欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

SQL表值函數(shù)和標量值函數(shù)的區(qū)別

系統(tǒng) 2302 0
原文: SQL表值函數(shù)和標量值函數(shù)的區(qū)別

? 寫sql存儲過程經(jīng)常需要調(diào)用一些函數(shù)來使處理過程更加合理,也可以使函數(shù)復(fù)用性更強,不過在寫sql函數(shù)的時候可能會發(fā)現(xiàn),有些函數(shù)是在表值函數(shù)下寫的有些是在標量值下寫的,區(qū)別是表值函數(shù)只能返回一個表,標量值函數(shù)可以返回基類型。舉個例子,當用戶刪除一個節(jié)點的時候,是需要將當前節(jié)點下的所有子節(jié)點都刪掉,如果程序只傳一個當前節(jié)點,那就需要寫一個函數(shù)來得到當前節(jié)點下的所有子節(jié)點,這些子節(jié)點的信息就可以放到一個表中返回。

  1. ? ? ?
  2. ALTER ? FUNCTION ? testGetSubNodes? ?
  3. (? ?
  4. ? ? ? ? @nodeId? int ? ?
  5. )? ?
  6. RETURNS ? @t? TABLE ? ? ?
  7. (? ?
  8. ? ? ? ? id? bigint ? identity(1,1)? not ? null ,? ? ?
  9. ? ? ? ? nodeIds? int ,? ?
  10. ? ? ? ? nodeName? varchar (500)? ?
  11. )? ?
  12. AS ? ?
  13. BEGIN ? ?
  14. ? ? ? ? insert ? into ? @t? values (@nodeId, 'header' );? ? ?
  15. ? ? ? ? while? exists( select ? nodeid? from ? dbo.Tree? where ? parentid? in ? ( select ? nodeIds? from ? @t)? and ? nodeid? not ? in ( select ? nodeIds? from ? @t))? ?
  16. ? ? ? ? begin ? ?
  17. ? ? ? ? ? ? ? ? insert ? into ? @t? select ? nodeid,? nodename? from ? dbo.Tree? where ? parentid? in ? ( select ? nodeIds? from ? @t)? ?
  18. ? ? ? ? end ? ? ?
  19. ? ? ? ? RETURN ? ? ?
  20. END ? ?
? ? ? ? 這個函數(shù)的主要功能就是返回當前節(jié)點下的所有子節(jié)點,在存儲過程中寫select * from testGetSubNodes(nodeId)就可以返回表中的數(shù)據(jù)了。再寫一個標量值函數(shù)
  1. ? ALTER ? FUNCTION ? [dbo].[testGetSubNodes_]? ?
  2. (? ?
  3. ? ? ? ? @nodeId? int ? ?
  4. )? ?
  5. RETURNS ? int ? ?
  6. AS ? ?
  7. BEGIN ? ?
  8. ? ? ? ? declare ? @nodeCount? int ? ?
  9. ? ? ? ? select ? @nodeCount=5? from ? MenuTree? ?
  10. ? ? ? ? return ? @nodeCount? ?
  11. END ? ?
? ? ? ? 這個函數(shù)很簡單返回一個整型值,然后就可以在存儲過程中調(diào)用了,不過調(diào)用的方式有所不同,象上面的表值函數(shù)調(diào)用是不需要所有者的,只要寫函數(shù)名稱就可以,對于標量值函數(shù)來說,是需要加上所有者的,比如所有者是dboselect dbo.testGetSubNodes_,這樣就可以返回5,如果不加dbo,那sql會不認識這個函數(shù)。

SQL表值函數(shù)和標量值函數(shù)的區(qū)別


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

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

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦?。?!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 午夜精品久久久久久久99热浪潮 | 国产一二三四区中 | 欧美日批 | 久9久9精品视频在线观看 | 玖玖在线精品 | 91精品国产91久久久久久吃药 | 亚洲jizzjizz妇女 | 91精品国产露脸在线观看 | 欧美三级成版人版在线观看 | 中文字幕在线播放 | 一级欧美黄色片 | 97碰碰碰 | 亚洲综合久久久久久中文字幕 | 中文字幕在线电影观看 | 九一国产在线观看免费 | 国内精品视频在线观看 | 免费在线一区二区 | 国产乱肥老妇国产一区二 | 国产综合视频在线 | 欧美成视频在线观看 | 国产精品久久久久久亚洲调教 | 国产精品免费入口视频 | 中文字幕精品一区二区三区精品 | aaa在线| www.国产精| 很黄很暴力深夜爽爽无遮挡 | av免费在线观看网站 | 男女视频在线免费观看 | 亚洲精品成A人在线观看拍拍拍 | 日韩图区| 美味人妻2中文A片 | 色综合视频在线 | 欧美激情在线观看一区二区三区 | 欧美日韩不卡 | 91精品国产色综合久久不卡蜜臀 | 噜噜噜噜狠狠狠7777视频 | 国产精品岛国久久久久久久 | 精品国产一区二区三区久久久蜜月 | 欧美一级二级在线观看 | 国产精品27页 | 亚洲人和日本人jizz |