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

軟件下載吧

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

SQL開(kāi)發(fā)知識(shí):SQL Server中修改“用戶自定義表類型”問(wèn)題

時(shí)間:2024-03-13 13:57作者:下載吧人氣:25

前言

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

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

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

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

TableType的基本使用

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

SQL開(kāi)發(fā)知識(shí):SQL Server中修改“用戶自定義表類型”問(wèn)題

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

SQL開(kāi)發(fā)知識(shí):SQL Server中修改“用戶自定義表類型”問(wèn)題

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

SQL開(kāi)發(fā)知識(shí):SQL Server中修改“用戶自定義表類型”問(wèn)題

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

SQL開(kāi)發(fā)知識(shí):SQL Server中修改“用戶自定義表類型”問(wèn)題

TableType的修改

TableType類型不支持alter語(yǔ)法,也即無(wú)法直接修改TableType的定義

SQL開(kāi)發(fā)知識(shí):SQL Server中修改“用戶自定義表類型”問(wèn)題

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

SQL開(kāi)發(fā)知識(shí):SQL Server中修改“用戶自定義表類型”問(wèn)題

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

SQL開(kāi)發(fā)知識(shí):SQL Server中修改“用戶自定義表類型”問(wèn)題

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

SQL開(kāi)發(fā)知識(shí):SQL Server中修改“用戶自定義表類型”問(wèn)題

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

SQL開(kāi)發(fā)知識(shí):SQL Server中修改“用戶自定義表類型”問(wèn)題

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

SQL開(kāi)發(fā)知識(shí):SQL Server中修改“用戶自定義表類型”問(wèn)題

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

SQL開(kāi)發(fā)知識(shí):SQL Server中修改“用戶自定義表類型”問(wèn)題

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

SQL開(kāi)發(fā)知識(shí):SQL Server中修改“用戶自定義表類型”問(wèn)題

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

SQL開(kāi)發(fā)知識(shí):SQL Server中修改“用戶自定義表類型”問(wèn)題

這樣子,整個(gè)過(guò)程就無(wú)需因?yàn)樾薷腡ableType的定義而刪除引用了TableType的對(duì)象了,在修改了TableType的定義之后,引用了這個(gè)TableType的對(duì)象可以正常運(yùn)行,也可以根據(jù)修改之后的TableType做具體的使用

完整的腳本如下

–判斷Type是否存在,如果存在,重命名,隨后之后才再刪除,否則無(wú)法直接刪除
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,比如原來(lái)是四個(gè)字段,現(xiàn)在想修改為三個(gè)字段,或者原來(lái)有三個(gè)字段想加一個(gè)字段變成四個(gè)字段
CREATE TYPE dbo.MyTableType AS TABLE(
Id INT NOT NULL,
Name VARCHAR(255) NOT NULL,   Remark VARCHAR(255)
)
GO

–將原來(lái)引用將要?jiǎng)h除的TYPE全部重建一遍,否則原始存儲(chǔ)過(guò)程會(huì)報(bào)錯(cuò)
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(被第一步重名的那個(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_MyTableType
GO

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

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

網(wǎng)友評(píng)論

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

熱門(mén)閱覽

最新排行

公眾號(hào)

盖楼回复X

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

主站蜘蛛池模板: 天堂8在线天堂资源bt| 一本久久a久久精品亚洲| 欧美精品香蕉在线观看网| 欧美性大战XXXXX久久久√| 日本久久中文字幕精品| 国产在线精品国自产拍影院同性| 亚洲AV无码国产精品麻豆天美| 免费专区丝袜脚调教视频| 激情综合婷婷色五月蜜桃| 日本精高清区一| 国产人妖视频一区二区| 久久99精品国产免费观看 | 中文字幕一区二区三区乱码| 色播在线永久免费视频网站| 成年人的免费视频| 全彩福利本子h全彩在线观看| yy6080久久亚洲精品| 牛牛本精品99久久精品| 国产香蕉在线精彩视频| 亚洲国产成人久久一区二区三区| √天堂中文官网8在线| 班主任丝袜脚夹茎故事| 在线中文字幕网| 亚洲免费视频播放| 麻豆国产福利91在线| 欧美亚洲欧美区| 国产在线观看中文字幕| 久久久最新精品| 精品国产三级在线观看| 在线观看亚洲一区| 亚洲午夜久久久影院| 黄色片一级免费看| 把腿抬起来就可以吃到扇贝了| 再深点灬舒服灬太大了阅读| 久久久久久AV无码免费网站 | www..com色| 欧美成人精品第一区首页| 国产成人一区二区三区精品久久 | avtt天堂网久久精品| 欧美性大战久久久久xxx| 国产小视频在线观看网站|