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
--请问这里改如何写?
展开
 我来答
WHITE_WIN
2013-04-17 · TA获得超过6111个赞
知道大有可为答主
回答量:3759
采纳率:50%
帮助的人:1903万
展开全部
其实,限制修改可以使用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
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式