国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院

首頁 > 數(shù)據(jù)庫 > SQL Server > 正文

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

2024-08-31 01:05:05
字體:
來源:轉載
供稿:網(wǎng)友

前言

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

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

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

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

TableType的基本使用

如下創(chuàng)建一個用戶自定義表類型

sql,用戶自定義表類型,sqlserver自定義類型,sqlserver,自定義函數(shù)

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

sql,用戶自定義表類型,sqlserver自定義類型,sqlserver,自定義函數(shù)

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

sql,用戶自定義表類型,sqlserver自定義類型,sqlserver,自定義函數(shù)

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

sql,用戶自定義表類型,sqlserver自定義類型,sqlserver,自定義函數(shù)

TableType的修改

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

sql,用戶自定義表類型,sqlserver自定義類型,sqlserver,自定義函數(shù)

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

sql,用戶自定義表類型,sqlserver自定義類型,sqlserver,自定義函數(shù)

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

sql,用戶自定義表類型,sqlserver自定義類型,sqlserver,自定義函數(shù)

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

sql,用戶自定義表類型,sqlserver自定義類型,sqlserver,自定義函數(shù)

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

sql,用戶自定義表類型,sqlserver自定義類型,sqlserver,自定義函數(shù)

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

sql,用戶自定義表類型,sqlserver自定義類型,sqlserver,自定義函數(shù)

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

sql,用戶自定義表類型,sqlserver自定義類型,sqlserver,自定義函數(shù)

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

sql,用戶自定義表類型,sqlserver自定義類型,sqlserver,自定義函數(shù)

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

sql,用戶自定義表類型,sqlserver自定義類型,sqlserver,自定義函數(shù)

這樣子,整個過程就無需因為修改TableType的定義而刪除引用了TableType的對象了,在修改了TableType的定義之后,引用了這個TableType的對象可以正常運行,也可以根據(jù)修改之后的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,比如原來是四個字段,現(xiàn)在想修改為三個字段,或者原來有三個字段想加一個字段變成四個字段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 FORSELECT referencing_schema_name + '.' + referencing_entity_nameFROM 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_MyTableTypeGO--最后執(zhí)行授權GRANT EXECUTE ON TYPE::dbo.MyTableType TO publicGO

總結:

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

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

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


注:相關教程知識閱讀請移步到MSSQL教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院
久久久久久77777| 国产日本韩国在线播放| 国产一级免费在线观看| 狠狠操五月天| 天堂资源在线中文| 国产不卡在线| 日本电影在线观看| 国产一区二区三区福利| 精品国内自产拍在线视频| 夜夜爽视频导航| 黄色av免费在线| 精品街拍一区二区| av亚洲在线| 狠狠干天天爱| 伊人国产在线看一| 国产69精品久久久久孕妇国产69久久| 国产精品视频一区麻豆| 亚洲视频日韩| 中文字幕视频在线免费| 色综合久久五月天| 综合图区亚洲白拍在线| wwww亚洲| 在线免费观看黄色片| 国产亚av手机在线观看| a级在线观看| 精精国产xxxx视频在线| 国产麻豆精品视频一区二区| 精品视频麻豆入口| 麻豆视频国产| 亚洲电影先锋| av免费在线观看网站| 国产午夜视频在线观看| 麻豆精品传媒视频观看| av首页在线| 国产精品yjizz视频网一二区| 国产在线高潮| www.eeuss影院| www.五月色.com| av丝袜在线| 亚洲欧美国产另类首页| 国产精品乱码一区二区三区视频 | 91中文在线| 国产一卡2卡3卡免费网站| 欧美专区日韩| 黄色片视频在线观看| 久久99亚洲网美利坚合众国| 九色成人在线| 国产一卡2卡3卡四卡网站| 成在线人视频免费视频| 丁香花在线电影| 国产精品一区二区三区四区色| 国产麻豆视频| 国产精品人人爱一区二区白浆| 超碰在线97国产| 天堂资源在线中文| 国产偷窥洗澡视频| 国产一级片在线播放| 国产精品视频一区二区图片| 国产日本在线视频| 亚洲私人影吧| 国产精品一区二区资源| 91美女主播在线视频| 日本aⅴ写真网站免费| 丁香视频五月| 99热99re6国产在线播放| 四虎a级欧美在线观看| 国产免费高清| 精精国产xxxx视频在线| av高清资源| 国内精品一区视频| 精品一二三四| 中文字幕日本在线| 日本视频在线观看一区二区三区| 国产免费黄网站| 精品久久亚洲一级α| 国产乱妇乱子| 亚洲一区二区三区在线观看网站| 国产原创精品视频| 亚洲欧美精品日韩欧美| 五月天天在线| 青青草免费在线视频| 精灵使的剑舞无删减版在线观看| 成视频年人免费看黄网站| 国产福利在线播放| 国产精选在线视频拍拍拍| 亚洲欧美一区二区三区在线播放| 国产美女视频网站| 青青草在线播放| 在线播放www| 国产黄色片在线观看| 免费三级毛片| www.xxx黄| av在线不卡免费| av片在线观看| 一本久久精品| 天天干天天摸| 日本欧美在线视频免费观看| 亚洲欧美自拍另类| 99色在线观看| 中文产幕区在线观看| 国产夫妻视频| 精品电影在线| 亚洲精品视频区| www.久草.com| 国产精品作爱| 国产黄色网页| 永久免费网站在线| 日本成人网址| 久草网在线视频| 丁香婷婷在线| 国产xxxx做受性欧美88| 精品伦理一区二区| 日韩在线天堂| 狠狠干天天爱| 国产欧美在线观看视频| 91最新在线| аⅴ成人天堂中文在线| 福利在线国产| 国产va在线观看| 亚洲va国产日韩欧美精品色婷婷| 亚洲an天堂an在线观看| www在线视频观看| 国产日韩精品在线看| 亚洲高清在线免费| 国产精品亚洲第五区在线| 国产一级又黄| www在线视频观看| 国产一区二区三区美女秒播| 国产精品美女一区二区视频| 91亚洲天堂| 日本最新在线视频| 日p在线观看| 国产成a人亚洲精v品| 懂色av一区| av免费在线一区二区三区| 国产精品臀控福利在线观看| 亚洲综合激情六月婷婷在线观看| 国产原创av在线| 精品免费视频一卡2卡三卡4卡不卡| 人人在线视频| 精品无吗乱吗av国产爱色| 福利视频网站导航| 先锋av资源网| 国产娇喘精品一区二区三区图片| 欧美性猛交xxxx免费看久久| 国产对白叫床清晰在线播放| 国产在线观看av| 欧美精品一区二区三区免费| av片在线观看永久免费| 91在线超碰| 国产aa视频| 国产成人综合美国十次| 国产精品久久久久白浆| 中文字幕在线影院| 狠狠综合久久久综合| 欧美性猛交xxxx免费看久久| av在线天天| 四虎www视频| 99免费视频| 中文乱码字幕av网站| 精品一二三区视频| 精精国产xxxx视频在线动漫| 7777在线| av在线播放网| 久草福利资源在线视频| 久久五月精品| 成人日韩欧美| 国产精品国产三级国产试看| 国产高清av| 中文在线观看视频| av中文资源在线| 麻豆av在线| 国产精品视频二区三区| 国产三级在线看| 2021天堂中文幕一二区在线观| 国产91足控脚交在线观看| 在线观看国产视频| 免费不卡中文字幕视频| 国产九色porn网址| 91涩漫在线观看c| 日本视频在线观看一区二区三区| 欧美日韩**字幕一区| 国产在线视频精品视频免费看| 国产精品探花在线| 91www在线观看| 久青青在线观看视频国产| 国产九色视频| 夜夜操com| 国产在线色视频| 91九色在线看| 国产在线色视频| 影音av资源站| 国产香蕉视频在线观看| 亚洲成人国产综合| 国产一二在线观看| 麻豆视频国产| av天天在线| 国产娇喘精品一区二区三区图片| jlzzjlzz欧美大全| 国产91在线视频蝌蚪|