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

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条记录

高手请留下联系方式,或许以后我们有合作机会,谢了!
...全文
114 9 打赏 收藏 转发到动态 举报
写回复
用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一旦为负则立即停止替换?????
不清楚???
内容概要:本文详细介绍了利用Simulink进行变压器开路试验的电路连接配置与仿真实现方法,重点在于通过仿真手段还原实际电力系统中变压器在空载条件下的电气特性,从而深入理解其工作原理与性能表现。文章作为电力系统仿真系列研究的一部分,系统阐述了从电路模型搭建、参数设定、仿真运行到结果分析的完整流程,突出展示了MATLAB/Simulink在电力设备建模与教学科研中的强大功能与应用价值。; 适合人群:具备电力系统基础知识,熟悉MATLAB/Simulink仿真环境,从事电气工程、自动化及相关领域的研发人员,以及高年级本科生和研究生。; 使用场景及目标:①掌握变压器开路试验的基本原理与Simulink仿真建模的具体步骤;②通过仿真实验深入理解空载电流、铁芯损耗及励磁特性等关键参数的物理意义;③为后续开展变压器短路试验、暂态过程分析以及其他电力设备的仿真研究奠定理论与实践基础。; 阅读建议:建议结合Simulink软件动手实践,逐步构建并调试电路模型,重点关注各元件参数的设置方法与测量模块的应用技巧,同时推荐参考文中提及的其他相关仿真案例进行拓展学习,以全面提升对电力系统仿真实践的整体认知与操作能力。

34,876

社区成员

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

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