亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > SQL Server > 正文

動態給表添加刪除字段并同時修改它的插入更新存儲過程

2024-08-31 00:58:00
字體:
來源:轉載
供稿:網友
有一個表,用戶需要在后臺操作它,希望能對它動態進行添加刪除字段。這個功能也許沒有問題,但是它原有插入與更新的兩個存儲過程,也需要一起修改。因此Insus.NET實現了它,因此此文會讓你了解到怎樣動態為一個表添加刪除字段以及動態修改它的存儲過程

首先需要建一個表[A],這個表只有兩個字段,一個是[ID]自動增長,另一個是表[B]的字段名,存儲的每一筆記錄,即是用戶需要操作的表[B]的字段。這個表[A]需要建添加,更新,以及刪除的存儲過程,方便用戶在后臺方便操作,還有重點部分,需要寫觸發器。如有記錄對表[A]進行添加,更新或是刪除時,它會觸發去作表[B]相應操作,還要去修改表[B]的存儲過程。

動態修改表[B]的存儲過程:

復制代碼 代碼如下:


CREATE PROCEDURE [dbo].[usp_B_DymanicallyAlterStoreProcedure]
AS
DECLARE @VariableList NVARCHAR(MAX) = ''
DECLARE @FieldList NVARCHAR(MAX) = ''
DECLARE @ValueList NVARCHAR(MAX) = ''
DECLARE @FieldValueList NVARCHAR(MAX) = ''

DECLARE @I INT = 1, @R INT = 0
SET @R = (SELECT MAX([Id]) FROM [dbo].[A])
WHILE (@I <= @R)
BEGIN
DECLARE @fName NVARCHAR(100)
IF EXISTS(SELECT [Id] FROM [dbo].[A] WHERE [Id] = @I)
BEGIN
SELECT @fName = [FieldName] FROM [dbo].[A] WHERE [Id] = @I
SET @VariableList = @VariableList + ',@' + @fName +' DECIMAL(18,4)' --動態的字段數據類型都一樣
SET @FieldList = @FieldList + ',[' + @fName + ']'
SET @ValueList = @ValueList + ',@' + @fName
SET @FieldValueList = @FieldValueList + ',[' + @fName + '] = @' + @fName
END
SET @I = @I + 1
END

DECLARE @sql_I NVARCHAR(MAX),@sql_U NVARCHAR(MAX)
SET @sql_I = '
ALTER PROCEDURE [dbo].[usp_B_Insert]
(
@ItemCode NVARCHAR(50)
'+ @VariableList +'
)
AS
INSERT INTO [dbo].[B] ([ItemCode]'+ @FieldList +') VALUES (@ItemCode'+ @ValueList +')
'
EXECUTE sp_EXECUTESQL @sql_I;

SET @sql_U = '
ALTER PROCEDURE [dbo].[usp_B_Update]
(
@Id INT,
@ItemCode NVARCHAR(50)
'+ @VariableList +'
)
AS
UPDATE [dbo].[B] SET [ItemCode] = @ItemCode'+ @FieldValueList +' WHERE [Id] = @Id
'
EXECUTE sp_EXECUTESQL @sql_U;


表[A]的插入觸發器:

復制代碼 代碼如下:


CREATE TRIGGER [dbo].[tri_A_Insert] ON [dbo].[A]
FOR INSERT
AS
BEGIN
SET NOCOUNT ON
DECLARE @FieldName NVARCHAR(50)
SELECT @FieldName = [FieldName] FROM INSERTED

EXECUTE('IF NOT EXISTS(SELECT * FROM SYSCOLUMNS WHERE [id] = OBJECT_ID(''B'') AND [name] = '''+ @FieldName +''')
ALTER TABLE [B] ADD ['+ @FieldName +'] DECIMAL(18,4) NULL')

EXECUTE [dbo].[usp_B_DymanicallyAlterStoreProcedure];
END


表[A]刪除觸發器:

復制代碼 代碼如下:


CREATE TRIGGER [dbo].[tri_A_Delete] ON [dbo].[A]
FOR DELETE
AS
BEGIN
SET NOCOUNT ON
DECLARE @FieldName NVARCHAR(50)
SELECT @FieldName = [FieldName] FROM DELETED

EXECUTE('IF EXISTS(SELECT * FROM SYSCOLUMNS WHERE [id] = OBJECT_ID(''B'') AND [name] = '''+ @FieldName +''')
ALTER TABLE [B] DROP COLUMN ['+ @FieldName +']')

EXECUTE [dbo].[usp_B_DymanicallyAlterStoreProcedure];
END

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久久免费精品国产| 亚洲自拍偷拍色片视频| 伊人久久五月天| 亚洲成人精品久久久| 日韩大胆人体377p| 国产精品成人av在线| 国产精品久久久久福利| 国产欧美最新羞羞视频在线观看| 日韩成人在线网站| 91精品久久久久久久久久久久久| 亚洲国产精久久久久久久| 久久亚洲精品毛片| 亚洲一区二区久久久久久久| 成人国内精品久久久久一区| 精品国产一区二区三区久久狼5月| 日韩成人小视频| 8050国产精品久久久久久| 成人精品aaaa网站| 国产精品av免费在线观看| 久久伊人精品一区二区三区| 欧美色欧美亚洲高清在线视频| 欧美专区日韩视频| 亚洲第一区在线观看| 中文字幕久热精品在线视频| 欧美高跟鞋交xxxxxhd| 日韩色av导航| 久久久久久国产精品| 在线免费观看羞羞视频一区二区| 亚洲精品国精品久久99热| 精品女厕一区二区三区| 久久91亚洲精品中文字幕奶水| 亚洲激情视频网| 亚洲精品国精品久久99热| 欧美精品精品精品精品免费| 91精品91久久久久久| 日韩欧美成人网| 国产成人欧美在线观看| 国产精品极品美女粉嫩高清在线| 亚洲精品自拍第一页| 欧美一区视频在线| 欧美人交a欧美精品| 亚洲欧美日韩国产中文专区| 欧美韩日一区二区| 久久久亚洲天堂| 日韩精品在线观看一区二区| 国产有码在线一区二区视频| 日韩欧美在线字幕| 日本久久久a级免费| 国产精品你懂得| 久久久久免费精品国产| 欧美福利在线观看| 另类视频在线观看| 亚洲福利视频免费观看| 人人爽久久涩噜噜噜网站| 97超碰国产精品女人人人爽| 丰满岳妇乱一区二区三区| 国产精品丝袜久久久久久不卡| 中文字幕在线亚洲| 日韩美女在线观看| 午夜精品久久久久久久男人的天堂| 亚洲美女av黄| 粉嫩av一区二区三区免费野| 韩国三级电影久久久久久| 欧美日韩美女视频| 91精品国产综合久久久久久蜜臀| 欧美精品在线观看91| 日韩美女写真福利在线观看| 成人免费视频xnxx.com| 亚洲视频免费一区| 日韩欧美亚洲成人| 亚洲人成电影在线播放| 亚洲尤物视频网| 久久久亚洲欧洲日产国码aⅴ| 国产精品国产三级国产aⅴ浪潮| 国产美女高潮久久白浆| 国产精品老牛影院在线观看| 欧美一区视频在线| 精品国产福利在线| 日韩精品在线免费观看| 亚洲欧美自拍一区| 91禁外国网站| 欧美xxxx综合视频| 最好看的2019年中文视频| 亚洲成年人在线| 久久人人爽人人| 精品视频www| 91精品久久久久久综合乱菊| 91精品国产色综合| 欧美猛男性生活免费| 日韩一区二区三区在线播放| 欧美激情一级精品国产| 国产精品久久久久91| 超碰精品一区二区三区乱码| 欧美精品在线免费播放| 欧美精品在线视频观看| 久久精品视频中文字幕| 精品亚洲一区二区三区四区五区| 中文字幕精品一区久久久久| 日日骚久久av| 精品一区精品二区| 国产精品亚洲аv天堂网| 国产精品视频大全| 国产精品99久久久久久www| 亚洲一区二区免费| 国产欧美精品xxxx另类| 色妞一区二区三区| 精品夜色国产国偷在线| 伊人久久男人天堂| 国产福利成人在线| 欧美肥臀大乳一区二区免费视频| 高清欧美性猛交xxxx| 国产亚洲综合久久| 日韩毛片在线观看| 欧美裸体xxxx极品少妇软件| 亚洲网站在线看| 亚洲精品电影久久久| 久久久国产成人精品| 国产免费一区二区三区在线能观看| 色777狠狠综合秋免鲁丝| 在线色欧美三级视频| 亚洲 日韩 国产第一| 亚洲欧美福利视频| 亚洲国产婷婷香蕉久久久久久| 九九热精品视频| 日韩国产一区三区| 欧美亚洲日本黄色| 国产欧美精品xxxx另类| 精品一区二区三区四区| 欧美极品少妇xxxxⅹ免费视频| 91国产一区在线| 中文国产亚洲喷潮| 欧美激情免费在线| 国产在线播放不卡| 久久久久国产精品www| 久久综合国产精品台湾中文娱乐网| 日本精品在线视频| 成人午夜一级二级三级| 日韩免费在线播放| 国产成人综合久久| 久久网福利资源网站| 国产乱人伦真实精品视频| 一区二区亚洲欧洲国产日韩| 97色在线观看免费视频| 国产精品久久久久久久久久东京| 亚洲美女自拍视频| 亚洲aa中文字幕| 不卡伊人av在线播放| 欧美精品免费在线| 国产精品久久久久久久久免费| 国产精品三级网站| 亚洲一级片在线看| 亚洲人成免费电影| 91大神在线播放精品| 欧美激情日韩图片| 中文字幕国产日韩| 精品欧美国产一区二区三区| 午夜精品99久久免费| 91丝袜美腿美女视频网站| 伊人伊人伊人久久| 91精品国产九九九久久久亚洲| 在线日韩精品视频| 国产97在线视频| 最新国产精品拍自在线播放| 亚洲美女中文字幕|