亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > 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中修改“用戶自定義表類型”問題的分析與方法的相關信息資訊供網民參考!
  • 推薦文章
    99久久精品国产国产毛片| 台湾美女古装一级毛片| 国产亚洲精品aaa大片| 精品视频免费看| 日韩专区一区| 国产国产人免费视频成69堂| 亚洲精品影院一区二区| 国产高清在线精品一区a| 日本在线www| 国产a免费观看| 麻豆午夜视频| 国产a视频| 91麻豆精品国产综合久久久| 四虎影视久久| 日韩中文字幕在线亚洲一区| 成人免费观看网欧美片| 成人免费一级纶理片| 在线观看成人网 | 青草国产在线| 国产福利免费观看| 国产一区二区精品| 亚飞与亚基在线观看| 精品视频一区二区三区免费| 日韩avdvd| 亚洲精品永久一区| 美女被草网站| 国产91精品一区| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 天天做日日爱夜夜爽| 日韩字幕在线| 欧美激情中文字幕一区二区| 国产伦精品一区三区视频| 韩国三级视频网站| 黄视频网站在线观看| 久久成人亚洲| 成人在免费观看视频国产| 香蕉视频三级| 黄色短视屏| 高清一级做a爱过程不卡视频| 天天做人人爱夜夜爽2020| 欧美一级视频免费观看| 成人影院一区二区三区| 日本在线不卡免费视频一区| 国产麻豆精品免费密入口| 亚洲 欧美 91| 亚洲精品影院久久久久久| 国产极品精频在线观看| 美女免费精品视频在线观看| 免费毛片播放| 国产网站免费在线观看| 99色视频在线观看| 亚洲女人国产香蕉久久精品| 国产成人精品影视| 日韩av片免费播放| 精品视频在线观看一区二区三区| 精品久久久久久影院免费| 国产a网| 99久久精品国产国产毛片| 色综合久久久久综合体桃花网| 欧美激情一区二区三区视频 | 999久久66久6只有精品| 亚洲精品中文字幕久久久久久| 九九精品影院| 欧美国产日韩在线| 精品国产三级a| 精品国产亚洲一区二区三区| 国产一区二区精品久久91| 国产美女在线观看| 天天做日日干| 麻豆系列 在线视频| 国产亚洲免费观看| 台湾美女古装一级毛片| 亚洲 男人 天堂| 国产不卡高清在线观看视频| 国产伦精品一区三区视频| 日韩免费在线观看视频| 国产一区二区精品| 久久久久久久免费视频| 久久99这里只有精品国产| 欧美另类videosbestsex视频| 国产91精品一区| 成人免费观看的视频黄页| 国产一区免费观看| 欧美激情在线精品video| 国产一区二区精品久久91| 免费的黄视频| 日韩专区亚洲综合久久| 日韩字幕在线| 99色吧| 成人高清护士在线播放| 色综合久久天天综合| 日韩一级黄色| 欧美国产日韩一区二区三区| 国产网站免费| 毛片高清| 99久久精品国产国产毛片| 国产高清视频免费| 日韩专区在线播放| 成人免费观看的视频黄页| 麻豆系列 在线视频| 免费国产在线视频| 精品视频在线看| 999久久66久6只有精品| 精品国产三级a| 九九九国产| 精品国产一区二区三区久久久蜜臀| 深夜做爰性大片中文| 精品毛片视频| 亚洲 男人 天堂| 国产韩国精品一区二区三区| 日本在线www| 日本免费看视频| 国产激情一区二区三区| 日本伦理网站| 国产伦精品一区二区三区无广告| 91麻豆精品国产自产在线| 久久精品成人一区二区三区| 欧美1区| 日本特黄特色aa大片免费| 97视频免费在线| 国产伦久视频免费观看 视频| 欧美另类videosbestsex高清| 欧美日本国产| 四虎影视久久| 韩国三级视频网站| 日韩av东京社区男人的天堂| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 国产视频一区二区在线播放| 亚洲女人国产香蕉久久精品| 国产精品免费久久| 午夜欧美福利| 精品国产香蕉在线播出 | 精品毛片视频| 国产伦精品一区三区视频 | 国产极品精频在线观看| 国产精品免费久久| 日韩av成人| 九九热国产视频| 国产不卡高清在线观看视频| 超级乱淫黄漫画免费| 国产综合成人观看在线| 天天色色色| 欧美激情一区二区三区视频高清| 国产福利免费视频| 韩国毛片免费大片| 国产一区二区精品| 日本乱中文字幕系列| 黄色免费三级| 精品视频在线观看免费| 美女被草网站| 日韩专区亚洲综合久久| 欧美爱爱动态| 黄色短视屏| 尤物视频网站在线观看| 色综合久久久久综合体桃花网| 欧美1卡一卡二卡三新区| 99热精品在线| 精品在线观看一区| 亚洲 国产精品 日韩| 日韩av片免费播放| 精品国产亚洲一区二区三区| 国产视频一区二区三区四区| 四虎论坛| 久久精品成人一区二区三区| 天天色色色| 国产一区二区精品久| 久久国产影视免费精品| 久久成人亚洲| 黄视频网站在线免费观看| 精品视频在线看| 亚洲精品久久久中文字| 色综合久久久久综合体桃花网| 一级女性全黄久久生活片| 国产网站免费视频| 精品视频在线看| 精品久久久久久影院免费| 日韩免费在线视频| 久久久久久久网| 久久久久久久久综合影视网| 精品国产一区二区三区久久久蜜臀 | 国产伦理精品| 欧美激情在线精品video| 国产国语在线播放视频| 久久久久久久免费视频| 九九九国产| 国产a视频| 日本免费看视频| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 亚飞与亚基在线观看| 99久久精品费精品国产一区二区| 精品国产亚洲人成在线| 日韩中文字幕一区| 日本免费乱理伦片在线观看2018| 精品视频在线看| 日韩中文字幕在线观看视频| 国产麻豆精品视频| 99热热久久| 午夜家庭影院| 欧美国产日韩精品| 久久久久久久男人的天堂|