sql server 按要求创建一个触发器

表Employees,有id,name,phone三列

按要求创建一个触发器,当update id时,不进行update操作,并给出提示。

CREATE TRIGGER emp_update
ON Employees
INSTEAD OF UPDATE
AS
IF (SELECT idFROM DELETED) <> (SELECT idFROM INSERTED)
PRINT '不允许对id字段值进行修改!'
ELSE
--请问这里改如何写?

其实,限制修改可以使用for UPDATE 触发器结合事务操作,如果更新了限制字段则报错并回滚更改操作。使用INSTED操作有点麻烦,但可以这样实现:
CREATE TRIGGER emp_update
ON Employees
INSTEAD OF UPDATE
AS
declare @Yid int,@Yname varchar(100),@Yphone varchar(50),
@id int,@name varchar(100),@phone varchar(50)

SELECT @ID=ID,@PHONE=PHONE,@NAME=NAME FROM INSERTED
SELECT @YID=ID,@YPHONE=PHONE,@YNAME=NAME FROM DELETED

IF @ID <> @YID

BEGIN
RAISERROR( '不允许对id字段值进行修改!',16,1) --此句一般是这样提交前台,并终止执行。
RETURN
END
ELSE
UPDATE EMPLOYEES SET NAME=@NAME,PHONE=@PHONE WHERE ID=@ID
GO
温馨提示:答案为网友推荐,仅供参考
相似回答