婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 動態(tài)給表添加刪除字段并同時修改它的插入更新存儲過程

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

熱門標(biāo)簽:銀川高頻外呼回?fù)芟到y(tǒng)多少錢 數(shù)字匠心電銷機(jī)器人 成都電話外呼系統(tǒng)一般多少錢 al智能電話機(jī)器人 如何做地圖標(biāo)注圖鋪 陜西電銷外呼系統(tǒng)好用嗎 蘭州語音外呼系統(tǒng)運(yùn)營商 最新人工智能電銷機(jī)器人 沒聽見電話機(jī)器人幫你接
有一個表,用戶需要在后臺操作它,希望能對它動態(tài)進(jìn)行添加刪除字段。這個功能也許沒有問題,但是它原有插入與更新的兩個存儲過程,也需要一起修改。因此Insus.NET實(shí)現(xiàn)了它,因此此文會讓你了解到怎樣動態(tài)為一個表添加刪除字段以及動態(tài)修改它的存儲過程

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

動態(tài)修改表[B]的存儲過程:
復(fù)制代碼 代碼如下:

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)' --動態(tài)的字段數(shù)據(jù)類型都一樣
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]的插入觸發(fā)器:
復(fù)制代碼 代碼如下:

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]刪除觸發(fā)器:
復(fù)制代碼 代碼如下:

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

標(biāo)簽:鹽城 邢臺 宜春 本溪 通化 巴彥淖爾 朔州 遼源

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《動態(tài)給表添加刪除字段并同時修改它的插入更新存儲過程》,本文關(guān)鍵詞  動態(tài),給,表,添加,刪除,字段,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《動態(tài)給表添加刪除字段并同時修改它的插入更新存儲過程》相關(guān)的同類信息!
  • 本頁收集關(guān)于動態(tài)給表添加刪除字段并同時修改它的插入更新存儲過程的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 敦化市| 西畴县| 彩票| 秦皇岛市| 丹棱县| 荔波县| 英山县| 梅河口市| 清流县| 汉阴县| 烟台市| 通州区| 共和县| 金溪县| 宁蒗| 仁布县| 嘉荫县| 二连浩特市| 无锡市| 扶余县| 潼关县| 平南县| 弋阳县| 锦州市| 华宁县| 任丘市| 涡阳县| 甘洛县| 辽阳市| 新昌县| 长治市| 和林格尔县| 千阳县| 剑川县| 大足县| 阆中市| 蓝山县| 卫辉市| 涿鹿县| 高要市| 赤城县|