SQL Server IF NOT EXISTS用法?

时间:2009-07-24 00:24:50

标签: sql sql-server stored-procedures

好的,我的架构是这样的:

表:Timesheet_Hours

列:

  • Timesheet_Id(PK,int)
  • Staff_Id(int)
  • BookedHours(int)
  • Posted_Flag(boolean)

这是该表的极简化版本,但它将用于此解释的目的。假设一个人只能有一个时间表记录。

我要做的是将记录添加到另一个名为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

1 个答案:

答案 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