标题:创建行级触发器的的问题
只看楼主
我是一匹好马
Rank: 1
等 级:新手上路
帖 子:40
专家分:0
注 册:2006-11-14
 问题点数:0 回复次数:4 
创建行级触发器的的问题
创建触发器的语句如下:
create trigger Update_OnHand
after insert on Goods
for Each Row
as begin
    insert into OnHand(GoodsId,Qty) values(new.GoodsId,0)
   end

报错如下:
服务器: 消息 170,级别 15,状态 1,过程 Update_OnHand,行 2
第 2 行: 'after' 附近有语法错误。
服务器: 消息 128,级别 15,状态 1,过程 Update_OnHand,行 5
在此上下文中不允许使用 'GoodsId'。此处只允许使用常量、表达式或变量。不允许使用列名。

请问如何解决呢?
搜索更多相关主题的帖子: 触发器 服务器 OnHand Update GoodsId 
2008-08-05 09:24
bb3852
Rank: 1
等 级:新手上路
帖 子:82
专家分:0
注 册:2008-4-21
得分:0 
看错误应该这样修改

1 after insert应该在后面
create trigger Update_OnHand
 on Goods after insert

2
values(new.GoodsId,0)
 改为
select new.GoodsId,0

[[it] 本帖最后由 bb3852 于 2008-8-5 09:53 编辑 [/it]]
2008-08-05 09:49
我是一匹好马
Rank: 1
等 级:新手上路
帖 子:40
专家分:0
注 册:2006-11-14
得分:0 
不是啊,加select不行的,顺便说一下我是在sql server2000 中创建的
2008-08-05 09:55
bb3852
Rank: 1
等 级:新手上路
帖 子:82
专家分:0
注 册:2008-4-21
得分:0 
create trigger Update_OnHand
 on Goods after insert
as begin
    insert into OnHand(GoodsId,Qty)
    select GoodsId,0
    from inserted
   end
2008-08-05 10:03
bb3852
Rank: 1
等 级:新手上路
帖 子:82
专家分:0
注 册:2008-4-21
得分:0 
出现什么错误啊
2008-08-05 10:03



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-226842-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.505566 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved