| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1811 人关注过本帖
标题:创建行级触发器的的问题
只看楼主 加入收藏
我是一匹好马
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
快速回复:创建行级触发器的的问题
数据加载中...
 
   



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

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