菜鸟问题:如何写顺序循环判断的存储过程(有以下例子),寻求优化,高手帮忙!!!

fansybox 2002-07-10 07:49:32
菜鸟问题:如何写顺序循环判断的存储过程(有以下例子),高手帮忙!!!
有A表(大数据量)和B表(大致只有800行记录)如下
A表 B表
ITEM QTY SOURCE_ITEM REPLACED_ITEM QTY
------------ ——————————————————
A1 30 A1 B1 100
A1 50 A2 B2 50
A1 30 ……
A1 40
A2 80
A1 10
……
目的要求:
1。 当A.TIEM=B.SOURCE_ITEM,将A.ITEM置换为B.REPLACED_ITEM,并将此时的B.QTY减去A.QTY(代表B.REPLACED_ITEM已经取代了SOURCE_ITEM多少个),直到B.QTY一旦为负则立即停止替换
2。如上的例子,替换结果应为如下:
A表 B表
ITEM QTY SOURCE_ITEM REPLACED_ITEM QTY
------------ ——————————————————
B1 30 A1 B1 -10
B1 50 A2 B2 -30
B1 30 ……
A1 40
B2 80
A1 10
……
3。是否有最优化的方法,每次处理,A表有8万条记录,B表有1000条记录

高手请留下联系方式,或许以后我们有合作机会,谢了!
...全文
59 9 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
fansybox 2002-07-10
  • 打赏
  • 举报
回复
谢谢 j9988(j9988) 的热心帮助,可否留个MSN或YAHOO MESSEGER呢?
我近期会测试一下,谢谢!
fansybox 2002-07-10
  • 打赏
  • 举报
回复
谢谢 j9988(j9988) 的热心帮助,可否留个MSN或YAHOO MESSEGER呢?
我近期会测试一下,谢谢!
fansybox 2002-07-10
  • 打赏
  • 举报
回复
答复Yang_(扬帆破浪)“你的SOURCE_ITEM REPLACED_ITEM 会不会重复?”:
不会重复的,SOURCE_ITEM是主键。
j9988 2002-07-10
  • 打赏
  • 举报
回复
要提高点速度要用两游标:
1.
select source_item from tableB
2.
select myid,item,qty from tableA where item= --
@(tableB.source_item)
3.
第二游标运行时,当@@rowcount=0则break
j9988 2002-07-10
  • 打赏
  • 举报
回复
我上面原原始数据跟你的不一样,所以结果有些差别,但应符合要求
j9988 2002-07-10
  • 打赏
  • 举报
回复
没法,A表重复,只有先用以下语句:
alter table tableA add myid int identity
go

过程:
declare @id char(10)
declare @qtyA int
declare @item char(10)
declare readA cursor for
select myid,item,qty from tableA
open readA
fetch next from readA into @id,@item,@qtyA


while @@fetch_status<>-1
begin
update tableB set qty=qty-@qtyA where source_item=@item and qty>=0
if @@rowcount>0
update tableA set item=(select replace_item from tableB where source_item=@item) where myid=@id
fetch next from readA into @id,@item,@qtyA
end
close readA
deallocate readA

结果:

item qty myid
---------- ----------- -----------
B1 40 1
B1 50 2
B1 30 3
A1 50 4
B2 80 5
A1 10 6

source_item replace_item qty
----------- ------------ -----------
A1 B1 -20
A2 B2 -30

(所影响的行数为 2 行)
Yang_ 2002-07-10
  • 打赏
  • 举报
回复
你的SOURCE_ITEM REPLACED_ITEM 会不会重复?
我的意思是你的B表会不会出现以下数据:

SOURCE_ITEM REPLACED_ITEM QTY
A1 B1 100
B1 XX 50
Yang_ 2002-07-10
  • 打赏
  • 举报
回复
用游标可以处理,但是速度快不了。
leimin 2002-07-10
  • 打赏
  • 举报
回复
(代表B.REPLACED_ITEM已经取代了SOURCE_ITEM多少个),直到B.QTY一旦为负则立即停止替换?????
不清楚???

34,838

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧