SQL 将整行写入另一个的更新触发器 table
SQL Update Trigger for writing entire row to another table
我昨天发布了一个问题,这是相关的。我有一个 table 叫做 People_Master
CREATE TABLE [dbo].[People_Master](
[ID] [int] IDENTITY(900001,1) NOT NULL,
[Email] [nvarchar](50) NULL,
[FirstName] [nvarchar](50) NULL,
[uac] [int] NULL,
[department] [nvarchar](50) NULL,
CONSTRAINT [PK_People_Master] PRIMARY KEY CLUSTERED
(
[ID] ASC
)
我还创建了另一个 table,名为 People_Delta
CREATE TABLE [dbo].[People_Delta](
[ID] [int] NOT NULL,
[Email] [nvarchar](50) NULL,
[FirstName] [nvarchar](50) NULL,
[uac] [int] NULL,
[Department] [nvarchar](50) NULL,
[change_type] [nvarchar](10) NULL
) ON [PRIMARY]
请注意,我在 People_Delta 中多了一列,名为“change_type”
现在我正在尝试为 People_Master 编写一个更新触发器,这样当它发生更新时,它应该将整行写入 People_Delta 并设置 change_type至 "Modify".
这是我写的触发器(我不擅长SQL。哈哈!)
CREATE TRIGGER [dbo].[TR_Update]
ON [dbo].[People_Master]
AFTER Update
AS
BEGIN
-- SET NOCOUNT ON added to prevent extra result sets from
-- interfering with SELECT statements.
SET NOCOUNT ON;
Declare @RowCount int
Declare @ID int
--Create a temp table to hold the inserted data.
Declare @TempTable As Table
(
[ID] [int],
[Email] [nvarchar](50) ,
[FirstName] [nvarchar](50),
[uac] [int] ,
[department] [nvarchar](50)
)
Insert Into @TempTable (ID,Email,FirstName,uac,department)
select
ID,
Email,
FirstName,
uac,
department
from
inserted
select @ID = ID from inserted
--check if the row for this ID doesnt exist already.
Select @RowCount=COUNT(*) from People_Delta where People_Delta.ID = @ID and People_Delta.change_type = 'Modify';
if(@RowCount = 0)
Begin
Insert into People_Delta (ID,Email,FirstName,uac,Department,change_type)
values (@TempTable.ID,@TempTable.Email,@TempTable.FirstName,@TempTable.uac,@TempTable.department,'Modify');
END
END
GO
但是,当我执行这个触发器时,出现以下错误:
Msg 137, Level 16, State 1, Procedure TR_Update, Line 50
Must declare the scalar variable "@TempTable".
Msg 137, Level 16, State 1, Procedure TR_Update, Line 50
Must declare the scalar variable "@TempTable".
Msg 137, Level 16, State 1, Procedure TR_Update, Line 50
Must declare the scalar variable "@TempTable".
Msg 137, Level 16, State 1, Procedure TR_Update, Line 50
Must declare the scalar variable "@TempTable".
Msg 137, Level 16, State 1, Procedure TR_Update, Line 50
Must declare the scalar variable "@TempTable".
我做错了什么?请帮忙!
GT.
试试这个触发器。
更改了此插入查询
Insert into People_Delta (ID,Email,FirstName,uac,Department,change_type)
values (@TempTable.ID,@TempTable.Email,@TempTable.FirstName,@TempTable.uac,
@TempTable.department,'Modify');
至
Insert into People_Delta (ID,Email,FirstName,uac,Department,change_type)
select ID, Email,FirstName, uac, department, 'Modify' from
inserted
更新触发器:
CREATE TRIGGER [dbo].[TR_Update]
ON [dbo].[People_Master]
AFTER Update
AS
BEGIN
-- SET NOCOUNT ON added to prevent extra result sets from
-- interfering with SELECT statements.
SET NOCOUNT ON;
Declare @ID int
select @ID = ID from inserted
If NOT EXISTS(Select People_Delta.ID from People_Delta where People_Delta.ID = @ID
and People_Delta.change_type = 'Modify')
BEGIN
Insert into People_Delta (ID,Email,FirstName,uac,Department,change_type)
select ID, Email,FirstName, uac, department, 'Modify' from
inserted
END
END
我昨天发布了一个问题,这是相关的。我有一个 table 叫做 People_Master
CREATE TABLE [dbo].[People_Master](
[ID] [int] IDENTITY(900001,1) NOT NULL,
[Email] [nvarchar](50) NULL,
[FirstName] [nvarchar](50) NULL,
[uac] [int] NULL,
[department] [nvarchar](50) NULL,
CONSTRAINT [PK_People_Master] PRIMARY KEY CLUSTERED
(
[ID] ASC
)
我还创建了另一个 table,名为 People_Delta
CREATE TABLE [dbo].[People_Delta](
[ID] [int] NOT NULL,
[Email] [nvarchar](50) NULL,
[FirstName] [nvarchar](50) NULL,
[uac] [int] NULL,
[Department] [nvarchar](50) NULL,
[change_type] [nvarchar](10) NULL
) ON [PRIMARY]
请注意,我在 People_Delta 中多了一列,名为“change_type”
现在我正在尝试为 People_Master 编写一个更新触发器,这样当它发生更新时,它应该将整行写入 People_Delta 并设置 change_type至 "Modify".
这是我写的触发器(我不擅长SQL。哈哈!)
CREATE TRIGGER [dbo].[TR_Update]
ON [dbo].[People_Master]
AFTER Update
AS
BEGIN
-- SET NOCOUNT ON added to prevent extra result sets from
-- interfering with SELECT statements.
SET NOCOUNT ON;
Declare @RowCount int
Declare @ID int
--Create a temp table to hold the inserted data.
Declare @TempTable As Table
(
[ID] [int],
[Email] [nvarchar](50) ,
[FirstName] [nvarchar](50),
[uac] [int] ,
[department] [nvarchar](50)
)
Insert Into @TempTable (ID,Email,FirstName,uac,department)
select
ID,
Email,
FirstName,
uac,
department
from
inserted
select @ID = ID from inserted
--check if the row for this ID doesnt exist already.
Select @RowCount=COUNT(*) from People_Delta where People_Delta.ID = @ID and People_Delta.change_type = 'Modify';
if(@RowCount = 0)
Begin
Insert into People_Delta (ID,Email,FirstName,uac,Department,change_type)
values (@TempTable.ID,@TempTable.Email,@TempTable.FirstName,@TempTable.uac,@TempTable.department,'Modify');
END
END
GO
但是,当我执行这个触发器时,出现以下错误:
Msg 137, Level 16, State 1, Procedure TR_Update, Line 50
Must declare the scalar variable "@TempTable".
Msg 137, Level 16, State 1, Procedure TR_Update, Line 50
Must declare the scalar variable "@TempTable".
Msg 137, Level 16, State 1, Procedure TR_Update, Line 50
Must declare the scalar variable "@TempTable".
Msg 137, Level 16, State 1, Procedure TR_Update, Line 50
Must declare the scalar variable "@TempTable".
Msg 137, Level 16, State 1, Procedure TR_Update, Line 50
Must declare the scalar variable "@TempTable".
我做错了什么?请帮忙! GT.
试试这个触发器。
更改了此插入查询
Insert into People_Delta (ID,Email,FirstName,uac,Department,change_type)
values (@TempTable.ID,@TempTable.Email,@TempTable.FirstName,@TempTable.uac,
@TempTable.department,'Modify');
至
Insert into People_Delta (ID,Email,FirstName,uac,Department,change_type)
select ID, Email,FirstName, uac, department, 'Modify' from
inserted
更新触发器:
CREATE TRIGGER [dbo].[TR_Update]
ON [dbo].[People_Master]
AFTER Update
AS
BEGIN
-- SET NOCOUNT ON added to prevent extra result sets from
-- interfering with SELECT statements.
SET NOCOUNT ON;
Declare @ID int
select @ID = ID from inserted
If NOT EXISTS(Select People_Delta.ID from People_Delta where People_Delta.ID = @ID
and People_Delta.change_type = 'Modify')
BEGIN
Insert into People_Delta (ID,Email,FirstName,uac,Department,change_type)
select ID, Email,FirstName, uac, department, 'Modify' from
inserted
END
END