亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

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

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

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

  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 ? ?
? ? ? ? 這個(gè)函數(shù)的主要功能就是返回當(dāng)前節(jié)點(diǎn)下的所有子節(jié)點(diǎn),在存儲(chǔ)過(guò)程中寫(xiě)select * from testGetSubNodes(nodeId)就可以返回表中的數(shù)據(jù)了。再寫(xiě)一個(gè)標(biāo)量值函數(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 ? ?
? ? ? ? 這個(gè)函數(shù)很簡(jiǎn)單返回一個(gè)整型值,然后就可以在存儲(chǔ)過(guò)程中調(diào)用了,不過(guò)調(diào)用的方式有所不同,象上面的表值函數(shù)調(diào)用是不需要所有者的,只要寫(xiě)函數(shù)名稱(chēng)就可以,對(duì)于標(biāo)量值函數(shù)來(lái)說(shuō),是需要加上所有者的,比如所有者是dboselect dbo.testGetSubNodes_,這樣就可以返回5,如果不加dbo,那sql會(huì)不認(rèn)識(shí)這個(gè)函數(shù)。

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


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

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

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

【本文對(duì)您有幫助就好】

您的支持是博主寫(xiě)作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 国产精品视频福利视频网 | 欧美成人午夜做爰视频在线观看 | 天天干天天天天 | 久久久久国产精品免费网站 | 在线观看免费精品国产 | 99久久99热精品免费观看国产 | 国产成人91 | a在线观看免费视频 | 日本欧美一区二区三区乱码 | 日本免费视屏 | 亚洲精品免费观看 | 亚洲精品久久片久久 | 黄色录像日本 | 精品久久久久久综合日本 | 日韩高清在线播放不卡 | 久久一区| 亚洲伦理网站 | 日本不卡免费高清一级视频 | 欧美日韩高清 | 2021中文字幕亚洲精品 | 全部免费特黄特色大片视频 | 国产成人精品综合久久久软件 | 91精品啪国产在线观看免费牛牛 | 深夜在线免费视频 | 国内精品一级毛片免费看 | 四虎影院在线视频 | 日韩精品中文字幕一区二区三区 | 玖玖在线精品 | 日日操操 | 色综合天天综合网国产成人网 | 欧美在线xxx | 亚洲激情在线看 | 手机看片欧美日韩 | 久久精品国产一区二区三区不卡 | 99在线观看精品视频 | 女人一级一级毛片 | 米奇精品一区二区三区 | 4虎影院永久地址www | 一级欧美日韩 | 农村寡妇一级毛片免费播放 | 欧美亚洲一二三区 |