下載吧 - 綠色安全的游戲和軟件下載中心

軟件下載吧

當(dāng)前位置:軟件下載吧 > 數(shù)據(jù)庫 > MS_SQL > SQL開發(fā)知識:SQL Server中修改“用戶自定義表類型”問題

SQL開發(fā)知識:SQL Server中修改“用戶自定義表類型”問題

時間:2024-03-13 13:57作者:下載吧人氣:27

前言

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

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

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

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

TableType的基本使用

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

SQL開發(fā)知識:SQL Server中修改“用戶自定義表類型”問題

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

SQL開發(fā)知識:SQL Server中修改“用戶自定義表類型”問題

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

SQL開發(fā)知識:SQL Server中修改“用戶自定義表類型”問題

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

SQL開發(fā)知識:SQL Server中修改“用戶自定義表類型”問題

TableType的修改

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

SQL開發(fā)知識:SQL Server中修改“用戶自定義表類型”問題

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

SQL開發(fā)知識:SQL Server中修改“用戶自定義表類型”問題

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

SQL開發(fā)知識:SQL Server中修改“用戶自定義表類型”問題

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

SQL開發(fā)知識:SQL Server中修改“用戶自定義表類型”問題

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

SQL開發(fā)知識:SQL Server中修改“用戶自定義表類型”問題

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

SQL開發(fā)知識:SQL Server中修改“用戶自定義表類型”問題

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

SQL開發(fā)知識:SQL Server中修改“用戶自定義表類型”問題

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

SQL開發(fā)知識:SQL Server中修改“用戶自定義表類型”問題

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

SQL開發(fā)知識:SQL Server中修改“用戶自定義表類型”問題

這樣子,整個過程就無需因為修改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 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

–最后執(zhí)行授權(quán)
GRANT EXECUTE ON TYPE::dbo.MyTableType TO public
GO

標(biāo)簽MSSQL,SQLServer,技術(shù)文檔,數(shù)據(jù)庫,SQLSERVER
查看所有評論+

網(wǎng)友評論

網(wǎng)友
您的評論需要經(jīng)過審核才能顯示

熱門閱覽

最新排行

公眾號

盖楼回复X

(您的评论需要经过审核才能显示)

主站蜘蛛池模板: 任你躁在线精品免费| 国产91在线免费| CHINESE熟女老女人HD视频| 最近中文字幕mv手机免费高清| 在线观看视频99| 久久精品国产亚洲AV香蕉| 男女性杂交内射女BBWXZ| 国产色丁香久久综合| 久久91综合国产91久久精品| 欧美视频免费一区二区三区| 国产一区二区三区日韩欧美| www成人在线观看| 日韩精品一区二区亚洲av观看| 人体大胆做受免费视频| 性刺激久久久久久久久 | 国产女人18毛片水真多1| 久久久久久夜精品精品免费啦| 欧美精品亚洲一区二区在线播放| 四虎e234hcom| 国产精品va一级二级三级| 在线人成精品免费视频| 九九精品免视看国产成人| 色偷偷亚洲第一综合网| 天天影院良辰美景好时光电视剧| 亚洲乱码无码永久不卡在线| 番肉动漫无修在线观看网站| 国产乱子伦视频大全| www四虎在线高清| 日本中文字幕有码在线视频| 人人妻人人澡人人爽人人精品 | 好吊妞视频免费观看va| 亚洲国产一成人久久精品| 福利视频一区二区| 国产激情一区二区三区成人91| 久久97久久97精品免视看秋霞| 桃子视频观看免费完整| 又色又爽又黄的三级视频在线观看 | 精品免费人成视频APP| 国产精品成人va在线观看入口 | 狼狼综合久久久久综合网| 四虎影视在线观看永久地址|