好的,我的架构是这样的:
表:Timesheet_Hours
列:
这是该表的极简化版本,但它将用于此解释的目的。假设一个人只能有一个时间表记录。
我要做的是将记录添加到另一个名为WorkLog的表中。这里的每条记录都有与之相关的时间。当该表更新时,我也想更新Timesheet_Hours。
在我更新Timesheet_Hours之前,我想首先检查相关的Timesheets是否尚未发布,然后我想检查是否实际上有一条记录要更新。
if语句的第一部分,检查时间表是否尚未发布,工作正常。问题是第二部分。检查它将要更新的记录已经存在。问题是它总是会引发错误。
注意:下面的代码是从WorkLog表上的更新,插入和删除触发器运行的存储过程中提取的。 @PersonID是该表的参数之一。如果我注释掉该语句的第二部分,则存储过程可以正常工作。
IF EXISTS
(
SELECT 1
FROM Timesheet_Hours
WHERE Posted_Flag = 1
AND Staff_Id = @PersonID
)
BEGIN
RAISERROR('Timesheets have already been posted!', 16, 1)
ROLLBACK TRAN
END
ELSE
IF NOT EXISTS
(
SELECT 1
FROM Timesheet_Hours
WHERE Staff_Id = @PersonID
)
BEGIN
RAISERROR('Default list has not been loaded!', 16, 1)
ROLLBACK TRAN
END
答案 0 :(得分:43)
您是否确认其中有一行Staff_Id = @PersonID?假设行存在,您发布的内容在测试脚本中工作正常。如果注释掉insert语句,则会引发错误。
set nocount on
create table Timesheet_Hours (Staff_Id int, BookedHours int, Posted_Flag bit)
insert into Timesheet_Hours (Staff_Id, BookedHours, Posted_Flag) values (1, 5.5, 0)
declare @PersonID int
set @PersonID = 1
IF EXISTS
(
SELECT 1
FROM Timesheet_Hours
WHERE Posted_Flag = 1
AND Staff_Id = @PersonID
)
BEGIN
RAISERROR('Timesheets have already been posted!', 16, 1)
ROLLBACK TRAN
END
ELSE
IF NOT EXISTS
(
SELECT 1
FROM Timesheet_Hours
WHERE Staff_Id = @PersonID
)
BEGIN
RAISERROR('Default list has not been loaded!', 16, 1)
ROLLBACK TRAN
END
ELSE
print 'No problems here'
drop table Timesheet_Hours