+ -
当前位置:首页 → 问答吧 → 触发器如何更新修改行之后的所有相关行

触发器如何更新修改行之后的所有相关行

时间:2011-12-07

来源:互联网

我有一个表,主键流水号是逐次自动加1的,其他列为ID、进货数量、出货数量、库存数。
我希望写个触发器令新增每行的库存数=同一ID上一行的库存数+本行进货数量-本行出货数量
另外当修改或者删除中间的某行最好能同步修改之后所有同ID行的库存数。

作者: shypzms   发布时间: 2011-12-07

SQL code
update tb 
set 库存数 = 进货数量-出货数量 + isnull((select top 1 库存数 from tb where id = t.id and 主键流水号 < t.主键流水号 order by 主键流水号 desc),0)
from tb t

作者: dawugui   发布时间: 2011-12-07

SQL code

这个数据库设计的不怎么合理啊。
如果一个ID已经有10W行的记录了,你删除了第10行,哪你不是要修改其他的9W多行。无语啊。


作者: mustudent   发布时间: 2011-12-07

只能怪工作流程不规范啊,要是有个定期盘点什么的还能把数据确定下来,现在需求的问题是下个月都有可能发现上个月的错误,真是很无语。

作者: shypzms   发布时间: 2011-12-07

不更改下表结构 这个不好做。

作者: fredrickhu   发布时间: 2011-12-07