请教 此bom表  @level产品层次 怎么展开运算的

mabuchi 2006-03-24 05:18:58
create procedure parts_explosion() //in @current char(25)

result(part_no char(25),structure_level integer,structure_qty decimal(15,6),children integer,siblings integer,open_children integer,same_level integer)

begin

declare @current char(25); //存放当前待查产品或零件

declare @level integer; //存放产品层次

declare @structure_qty decimal(15,4); //存放构成数量

select '最初产品编号' into @current; //后台测试用

create table #stack( //中间结果存表
current_item char(25) null,
part_level integer null,
part_qty decimal(15,4) null);

create table #parts( //最后返回结果存放表
part_no char(25) null,
structure_level integer null,
structure_qty decimal(15,6) null,
children integer null, //存放如果有子级产品.则1.否0.
siblings integer null, //存放是否邻居产品
open_children integer null, //前台用
same_level integer null, //前台用
);

/* SELECT @current='45860020A'*/

insert into #stack values(@current,1,1); //初始中间表

select 1 into @level;

while @level>0 loop

if exists(select* from #stack where part_level=@level) then

select current_item,part_qty into @current,

@structure_qty from #stack

where part_level=@level;

if @level<>1 then

insert into #parts values(@current,@level,@structure_qty,1,1,1,1)

end if

delete from #stack

where part_level=@level and current_item=@current;

insert into #stack

select part_no,@level+1,part_qty

from product_stru

where product_no=@current;

if @@rowcount>0 then

select @level+1 into @level;

if @@rowcount=1 then

update #parts set same_level=0

where part_no=@current

end if

else

update #parts set children=0

where part_no=@current

end if

else

select @level-1 into @level

end if

end loop
;

select part_no,structure_level,structure_qty,children,siblings,open_children,same_level from #parts

end


...全文
185 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
mabuchi 2006-03-25
  • 打赏
  • 举报
回复
up
mabuchi 2006-03-25
  • 打赏
  • 举报
回复
只能看懂一部份  哪位能否说一下
mabuchi 2006-03-25
  • 打赏
  • 举报
回复
oracal 差不多
Yang_ 2006-03-25
  • 打赏
  • 举报
回复
这什么代码?
不是sql server的吧
mabuchi 2006-03-25
  • 打赏
  • 举报
回复
if @@rowcount>0 then

select @level+1 into @level;

if @@rowcount=1 then

update #parts set same_level=0

where part_no=@current

end if

else

update #parts set children=0

where part_no=@current

end if

else

select @level-1 into @level

end if
这里怎么理解
内容概要:本文围绕基于Basisformer模型的时间序列锂离子电池SOC(State of Charge,荷电状态)预测展开研究,利用PyTorch框架实现深度学习模型的构建与训练。通过将历史充放电数据作为输入,Basisformer能够有效捕捉电池状态的动态变化特征,提升SOC预测精度。文中详细介绍了模型结构设计、数据预处理流程、训练策略及实验结果分析,并与传统方法进行对比,验证了该方法在复杂工况下的优越性与鲁棒性。该研究不仅展示了Basisformer在时序建模中的潜力,也为电池管理系统提供了高精度的状态估计解决方案。; 适合人群:具备一定Python编程基础和深度学习理论知识,熟悉PyTorch框架,从事电池管理系统、新能源汽车或智能预测方向研究的研究生、科研人员及工程技术人员。; 使用场景及目标:①应用于电动汽车、储能系统等领域的电池SOC高精度实时估算;②为电池健康管理(BMS)提供可靠的状态输入;③推动深度学习在时间序列预测中的实际落地,提升现有预测模型的泛化能力与稳定性; 阅读建议:建议读者结合标题为【锂电池SOC估计】【PyTorch】基于Basisformer时间序列锂离子电池SOC预测研究(python代码实现)的资源,重点研读所提供的Python代码,深入理解数据处理方式与模型网络结构的设计思路,尝试调整超参数以观察对预测性能的影响,从而全面掌握Basisformer在时序建模中的优势、适用边界及工程化实现路径。

27,581

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 应用实例
社区管理员
  • 应用实例社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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