婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > SQL Server中修改“用戶自定義表類型”問題的分析與方法

SQL Server中修改“用戶自定義表類型”問題的分析與方法

熱門標簽:奧威地圖標注多個地方 千呼電銷機器人價格 外呼系統電銷專用 京華物流公司地圖標注 怎樣在地圖上標注路線圖標 優質地圖標注 智能語音外呼系統選哪家 武漢長沙外呼系統方法和技巧 百度地圖標注不同路線

前言

SQL Server開發過程中,為了傳入數據集類型的變量(比如接受C#中的DataTable類型變量),需要定義“用戶自定義表類型”,通過“用戶自定義表類型”可以接收二維數據集作為參數,在需要修改“用戶自定義表類型”的時候,增加字段,刪除字段,修改字段類型等,它沒有像表一樣的alter table語法來進行修改。

只能通過刪除重建來實現,但是在刪除“用戶自定義表類型”的時候會提示有對象引用它(某些存儲過程用到了這個“用戶自定義表類型”),因此無法刪除。

為了達到公用的目的,有時候一個TableType可以在多個地方分別被引用到,這樣的話,勢必要先刪除所有的引用了這個“用戶自定義表類型”的對象(存儲過程等)

如果這個“用戶自定義表類型”被多個存儲過程引用,那么就要分別刪除多個引用了“用戶自定義表類型”的存儲過程,然后修改“用戶自定義表類型”,在重建存儲過程,這樣做起來似乎有點繞,這個問題可以用過EXEC sys.sp_refreshsqlmodule這個系統函數來簡介實現“用戶自定義表類型”的定義

TableType的基本使用

如下創建一個用戶自定義表類型

定義的TableType可以在用戶自定義表類型中找到

創建兩個存儲過程,分別用到了上面定義的用戶自定義表類型,模擬用戶自定義表類型被引用的情況

此時的存儲過程可以接收TableType參數并正常運行

TableType的修改

TableType類型不支持alter語法,也即無法直接修改TableType的定義

那么只能通過刪除TableType的方法來重建這個TableType,當刪除的時候,仍然報錯,提示“因為它正由對象 '***' 引用。可能還有其他對象在引用此類型。”

此時只能刪除引用了這個TableType的對象來解決,下面可以查到那些對象引用了某一個TableType,然后分別刪除,重建TableType,再重建存儲過程,有點繞彎子。

可以先將自定義的某個TableType重命名,重命名的過程中有一個警告,這里先忽略它,隨后可以直接Drop Type dbo.MyTableType

刪除原TableType之后,重建(重定義)TableType

重建TableType之后,先前存儲過程中用到這個TableType的存儲過程是無法編譯通過的

此時就需要重新刷新引用對象的定義

刷新完成之后,原存儲過程就可以正常編譯了

最后刪除原始的TableType被重命名的TableType(被第一步重名的那個)

這樣子,整個過程就無需因為修改TableType的定義而刪除引用了TableType的對象了,在修改了TableType的定義之后,引用了這個TableType的對象可以正常運行,也可以根據修改之后的TableType做具體的使用

完整的腳本如下

--判斷Type是否存在,如果存在,重命名,隨后之后才再刪除,否則無法直接刪除
IF EXISTS (SELECT 1 FROM sys.types t join sys.schemas s on t.schema_id=s.schema_id 
      and t.name='MyTableType' and s.name='dbo')
 EXEC sys.sp_rename 'dbo.MyTableType', 'obsoleting_MyTableType';
GO


--重建TYPE,比如原來是四個字段,現在想修改為三個字段,或者原來有三個字段想加一個字段變成四個字段
CREATE TYPE dbo.MyTableType AS TABLE(
 Id INT NOT NULL,
 Name VARCHAR(255) NOT NULL,   Remark VARCHAR(255)
)
GO

--將原來引用將要刪除的TYPE全部重建一遍,否則原始存儲過程會報錯
DECLARE @Name NVARCHAR(500);
DECLARE REF_CURSOR CURSOR FOR
SELECT referencing_schema_name + '.' + referencing_entity_name
FROM sys.dm_sql_referencing_entities('dbo.MyTableType', 'TYPE');
 OPEN REF_CURSOR;
 FETCH NEXT FROM REF_CURSOR INTO @Name;
 WHILE (@@FETCH_STATUS = 0)
 BEGIN
  EXEC sys.sp_refreshsqlmodule @name = @Name;
  FETCH NEXT FROM REF_CURSOR INTO @Name;
 END;
CLOSE REF_CURSOR;
DEALLOCATE REF_CURSOR;
GO

--最后刪除原始的被重命名的TableType(被第一步重名的那個)
IF EXISTS (SELECT 1 FROM sys.types t 
   join sys.schemas s on t.schema_id=s.schema_id 
   and t.name='obsoleting_MyTableType' and s.name='dbo')
 DROP TYPE dbo.obsoleting_MyTableType
GO

--最后執行授權
GRANT EXECUTE ON TYPE::dbo.MyTableType TO public
GO

總結:

TableType可以方便地接受二維數據作為參數,從而可以達到批量處理數據的目的,避免傳遞進去一大堆字符串,然后在對字符串解析的做法,從而可以在一定程度上提高sql的運行效率。

不過TableType的修改確實存在一定的問題,直接修改TableType會存在級聯刪除數據庫對象的情況,可以通過“曲線救國”的方式,來減小工作量的情況下修改TableType。

好了,以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • Sqlserver 表類型和表變量介紹

標簽:宿州 威海 天水 益陽 銅仁 七臺河 防疫戰設 來賓

巨人網絡通訊聲明:本文標題《SQL Server中修改“用戶自定義表類型”問題的分析與方法》,本文關鍵詞  SQL,Server,中,修改,用戶,自定義,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《SQL Server中修改“用戶自定義表類型”問題的分析與方法》相關的同類信息!
  • 本頁收集關于SQL Server中修改“用戶自定義表類型”問題的分析與方法的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产白丝网站精品污在线入口| 亚洲精品成a人| 欧美精品777| 欧美在线免费观看亚洲| 色综合色狠狠天天综合色| jiyouzz国产精品久久| 97精品久久久午夜一区二区三区 | 日韩精品一区二区三区蜜臀| 欧美精品一级二级三级| 69av一区二区三区| 日韩视频国产视频| 久久综合九色综合欧美亚洲| 精品国产电影一区二区| 国产精品水嫩水嫩| 亚洲另类在线一区| 天天操天天色综合| 麻豆精品一区二区综合av| 精品一区二区三区久久久| 国产夫妻精品视频| 99热在这里有精品免费| 欧美日韩在线电影| 欧美变态凌虐bdsm| 亚洲国产精品成人综合色在线婷婷| 国产精品网友自拍| 亚洲成年人影院| 国产伦精品一区二区三区视频青涩 | 人禽交欧美网站| 国产精品综合在线视频| aa级大片欧美| 欧美一区国产二区| 中文字幕一区二区三区在线观看 | 久久久高清一区二区三区| 国产精品毛片高清在线完整版| 亚洲精品乱码久久久久久黑人| 热久久久久久久| 91美女片黄在线观看91美女| 91精品国产日韩91久久久久久| 欧美国产精品专区| 日韩精品一级中文字幕精品视频免费观看 | 夜夜嗨av一区二区三区网页| 偷偷要91色婷婷| 波波电影院一区二区三区| 欧美疯狂做受xxxx富婆| 国产欧美一区二区三区网站 | 91香蕉视频污在线| 欧美成人精品高清在线播放| 亚洲情趣在线观看| 黄网站免费久久| 7777精品伊人久久久大香线蕉最新版| 国产欧美一区二区三区网站| 麻豆成人av在线| 欧美午夜精品理论片a级按摩| 久久老女人爱爱| 亚洲www啪成人一区二区麻豆| 成人av免费在线播放| 日韩视频一区二区三区在线播放| 亚洲免费色视频| 99视频精品在线| 国产精品国产三级国产普通话蜜臀| 强制捆绑调教一区二区| 欧美写真视频网站| 亚洲欧美电影院| 91亚洲精华国产精华精华液| 国产欧美视频在线观看| 国产剧情一区在线| 精品国产精品网麻豆系列| 日韩成人午夜电影| 欧美日韩精品欧美日韩精品一| 亚洲人吸女人奶水| eeuss国产一区二区三区| 国产亚洲va综合人人澡精品| 国产精品影视在线观看| 欧美精品一区二区三区蜜桃视频| 亚洲第一搞黄网站| 3d成人h动漫网站入口| 日韩国产欧美在线视频| 欧美日韩国产高清一区二区| 亚洲精品菠萝久久久久久久| 日本二三区不卡| 一级日本不卡的影视| 欧美系列日韩一区| 奇米精品一区二区三区四区| 日韩三级视频在线观看| 捆绑调教一区二区三区| 日韩三区在线观看| 国产馆精品极品| 中文字幕一区二区在线观看| 色婷婷综合久久| 视频一区在线播放| 精品日韩一区二区| 成人深夜视频在线观看| 亚洲精品成a人| 欧美久久久久久久久| 免费的成人av| 欧美激情中文字幕一区二区| av不卡一区二区三区| 一区二区久久久久久| 91精品综合久久久久久| 国产91丝袜在线观看| 一区二区三区蜜桃| 欧美成人video| 99r精品视频| 麻豆专区一区二区三区四区五区| 久久色中文字幕| 91成人在线免费观看| 日本成人中文字幕| 国产精品萝li| 日韩一级免费一区| www.日韩av| 久久成人免费网| 一区二区视频在线看| 日韩午夜电影在线观看| 97se亚洲国产综合自在线不卡| 天天影视网天天综合色在线播放| 久久精品免费在线观看| 欧美午夜视频网站| 精品午夜久久福利影院| 午夜精品久久久久久久蜜桃app| 久久久亚洲欧洲日产国码αv| 在线看一区二区| 国产高清在线精品| 日韩精品一级二级 | 欧美精品日日鲁夜夜添| 成人在线视频首页| 加勒比av一区二区| 天涯成人国产亚洲精品一区av| 中文av一区特黄| ww亚洲ww在线观看国产| 欧美色精品在线视频| 成人一区在线观看| 国产精品一区二区在线观看不卡| 午夜精品一区二区三区免费视频| 亚洲天堂中文字幕| 国产日韩精品一区| 久久中文娱乐网| 精品卡一卡二卡三卡四在线| 欧美喷潮久久久xxxxx| 91美女在线视频| 99精品欧美一区二区三区综合在线| 九九九精品视频| 丝袜诱惑制服诱惑色一区在线观看 | 欧美一三区三区四区免费在线看 | 午夜av一区二区| 亚洲午夜一二三区视频| 亚洲欧美日韩国产手机在线| 中文字幕久久午夜不卡| 国产精品少妇自拍| 成人免费一区二区三区在线观看| 久久精品在这里| 国产欧美日韩另类一区| 国产片一区二区| 欧美激情综合五月色丁香小说| 欧美va亚洲va香蕉在线| 欧美一级电影网站| 欧美大片顶级少妇| 精品成人私密视频| 国产亲近乱来精品视频| 国产精品嫩草影院av蜜臀| 国产精品对白交换视频| 亚洲欧美视频在线观看| 亚洲国产成人91porn| 日韩精品午夜视频| 蜜桃一区二区三区在线| 国产精品一级黄| 成人免费视频app| 欧美伊人精品成人久久综合97| 欧美视频一区在线观看| 欧美一区二区三区四区久久| 欧美大片一区二区| 亚洲欧洲日本在线| 午夜婷婷国产麻豆精品| 奇米影视在线99精品| 国内精品免费在线观看| 波多野结衣亚洲| 欧美一区二区三区视频免费播放| 精品久久久久久久人人人人传媒| 国产日韩高清在线| 亚洲gay无套男同| 国产在线乱码一区二区三区| jlzzjlzz国产精品久久| 欧美午夜一区二区| 国产欧美日产一区| 日韩一区精品字幕| 99久久国产综合色|国产精品| 91精品国产福利| 亚洲欧美国产高清| 狠狠色伊人亚洲综合成人| 91免费版pro下载短视频| 欧美一级日韩免费不卡| 18欧美乱大交hd1984| 免费人成黄页网站在线一区二区| 盗摄精品av一区二区三区| 7777精品伊人久久久大香线蕉超级流畅 | 欧美日韩在线不卡| 国产精品久久久久久亚洲伦| 亚洲成av人片在线| 91在线观看高清| 久久精品亚洲精品国产欧美kt∨ | 日韩免费在线观看| 亚洲一区日韩精品中文字幕|