本例示範在SQL Server中,當使用者添加一條欄位資訊資料到一個表中,通過觸發器相應在另一個表中自動增加一個對應的欄位。
1 首先建立一個欄位資訊表Fields
CREATE TABLE [dbo].[Fields] (
[FieldID] [int] IDENTITY (1, 1) NOT NULL ,
[Name] [varchar] (50) COLLATE Chinese_PRC_CI_AS NOT NULL ,
[DataType] [varchar] (50) COLLATE Chinese_PRC_CI_AS NOT NULL
) ON [PRIMARY]
GO
ALTER TABLE [dbo].[Fields] ADD
CONSTRAINT [PK_Fields] PRIMARY KEY CLUSTERED
(
[FieldID]
) ON [PRIMARY]
GO
2 建立一個動態欄位表Customeres, 當Fields每增加一條記錄,本表就相應增加一個欄位。
CREATE TABLE [dbo].[Customeres] (
[ID] [int] IDENTITY (1, 1) NOT NULL
) ON [PRIMARY]
GO
ALTER TABLE [dbo].[Customeres] ADD
CONSTRAINT [PK_Customeres] PRIMARY KEY CLUSTERED
(
[ID]
) ON [PRIMARY]
GO
3 為表Fields新增一個觸發器,當增加資料的時候,都會自動調用此觸發器。注意:欄位的長度寫入程式碼,只是為了示範目的,應根據自己的需要來動態調整長度。
CREATE TRIGGER trigger_addField ON Fields
FOR INSERT
AS
DECLARE @FieldID int,
@Name varchar(50),
@DataType varchar(50),
@SQL varchar(1000)
SELECT @FieldID = FieldID, @Name = [Name], @DataType = DataType
FROM Inserted
if not exists (SELECT * FROM syscolumns
where id=object_id('Customeres')
AND name=@Name)
BEGIN
SET @SQL = 'ALTER table Customeres add ' + @Name + ' '
+ @DataType + '(64) NULL'
EXEC (@SQL)
END
PRINT @Name + ',' + @DataType
4 示範,在查詢分析中執行
Insert into Fields ([name], DataType) values ('name', 'varchar')
參考來源:
Add a column to a table unless it already exists
Using Triggers In MS SQL Server