sql server 按要求创建一个触发器
表Employees,有id,name,phone三列按要求创建一个触发器,当updateid时,不进行update操作,并给出提示。CREATETRIGGERemp_u...
表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
--请问这里改如何写? 展开
按要求创建一个触发器,当update id时,不进行update操作,并给出提示。
CREATE TRIGGER emp_update
ON Employees
INSTEAD OF UPDATE
AS
IF (SELECT idFROM DELETED) <> (SELECT idFROM INSERTED)
PRINT '不允许对id字段值进行修改!'
ELSE
--请问这里改如何写? 展开
1个回答
展开全部
其实,限制修改可以使用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
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
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询