其实,限制修改可以使用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
温馨提示:答案为网友推荐,仅供参考