麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

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

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

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

前言

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

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

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

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

TableType的基本使用

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

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

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

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

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

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

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

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

TableType的修改

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

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

那么只能通過刪除TableType的方法來重建這個(gè)TableType,當(dāng)刪除的時(shí)候,仍然報(bào)錯(cuò),提示“因?yàn)樗蓪?duì)象 '***' 引用。可能還有其他對(duì)象在引用此類型。”

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

此時(shí)只能刪除引用了這個(gè)TableType的對(duì)象來解決,下面可以查到那些對(duì)象引用了某一個(gè)TableType,然后分別刪除,重建TableType,再重建存儲(chǔ)過程,有點(diǎn)繞彎子。

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

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

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

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

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

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

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

此時(shí)就需要重新刷新引用對(duì)象的定義

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

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

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

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

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

這樣子,整個(gè)過程就無需因?yàn)樾薷腡ableType的定義而刪除引用了TableType的對(duì)象了,在修改了TableType的定義之后,引用了這個(gè)TableType的對(duì)象可以正常運(yùn)行,也可以根據(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,比如原來是四個(gè)字段,現(xiàn)在想修改為三個(gè)字段,或者原來有三個(gè)字段想加一個(gè)字段變成四個(gè)字段CREATE TYPE dbo.MyTableType AS TABLE( Id INT NOT NULL, Name VARCHAR(255) NOT NULL,   Remark VARCHAR(255))GO--將原來引用將要?jiǎng)h除的TYPE全部重建一遍,否則原始存儲(chǔ)過程會(huì)報(bào)錯(cuò)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(被第一步重名的那個(gè))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í)行授權(quán)GRANT EXECUTE ON TYPE::dbo.MyTableType TO publicGO

總結(jié):

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

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

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


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到MSSQL教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 亚洲午夜影院在线观看 | 国产一级爱c视频 | 亚洲精品久久久久久下一站 | 干一夜综合 | 国产午夜精品久久久久婷 | 久久久久久久久久久久久久久伊免 | 欧美韩国日本在线 | 亚洲福利在线视频 | 国产欧美在线观看不卡一 | 亚洲午夜久久久精品一区二区三区 | 性猛交ⅹxxx乱巴西 在线播放中文 | 久久亚洲线观看视频 | 国产亚洲精品久久久久婷婷瑜伽 | 国产色视频一区 | 一夜新娘第三季免费观看 | 羞羞的视频在线 | 毛片大全在线观看 | 男女羞羞视频 | videos高潮 | 亚洲第一页综合 | 激情在线视频 | 亚洲一级片免费观看 | av黄色片网站 | 久久久久久久久久久久久久久伊免 | 欧美不卡三区 | 久草成人在线 | 亚洲第一页夜 | 一级毛片免费高清 | 国产精品美女久久久久久网站 | 看免费5xxaaa毛片 | 欧美成人高清在线 | 欧美精品一区二区三区在线 | 久久久久久久免费看 | 日韩欧美色综合 | 免费黄色大片网站 | 免费网址黄 | 黄色小视频免费在线观看 | 一级黄色淫片 | 黄色a级片视频 | 免费一级特黄毛片 | 亚洲精品有限 |