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

          軟件下載吧

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

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

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

          前言

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

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

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

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

          TableType的基本使用

          如下創建一個用戶自定義表類型

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

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

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

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

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

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

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

          TableType的修改

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

          標簽MSSQL,SQLServer,技術文檔,數據庫,SQLSERVER
          查看所有評論+

          網友評論

          網友
          您的評論需要經過審核才能顯示

          熱門閱覽

          最新排行

          公眾號

          盖楼回复X

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

          主站蜘蛛池模板: 免费观看一区二区三区| 91秒拍国产福利一区| 人妻AV中文字幕一区二区三区 | 日韩免费一区二区三区在线播放 | 中文字幕精品一区| 日韩一区二区在线免费观看| 精品成人乱色一区二区| 国产激情视频一区二区三区| 国产激情一区二区三区成人91| 在线免费视频一区二区| 亚洲av无码一区二区三区天堂 | 蜜臀AV免费一区二区三区| 免费萌白酱国产一区二区三区| 一区二区三区在线观看视频| 波多野结衣中文字幕一区| 韩国女主播一区二区| 亚洲av乱码中文一区二区三区| 99精品国产一区二区三区2021| 无码一区二区三区| 精品国产一区二区三区无码| 亚洲一区二区三区国产精品无码 | 日韩精品一区二区三区中文3d| 在线免费一区二区| 国产SUV精品一区二区88L| 麻豆一区二区三区蜜桃免费| 视频一区二区在线播放| 国产高清精品一区| 中文字幕一区二区免费| 日韩视频一区二区三区| 91精品国产一区| 日本在线电影一区二区三区| 免费视频精品一区二区| 国产品无码一区二区三区在线蜜桃 | 三上悠亚精品一区二区久久| av无码人妻一区二区三区牛牛| 高清一区二区三区免费视频| 国产免费一区二区三区| 最新中文字幕一区| 国产精品亚洲高清一区二区| 一区二区三区国产精品 | 免费萌白酱国产一区二区三区|