一种基于SQL的快速BOM展开方法与流程

文档序号:33730944发布日期:2023-04-06 03:40阅读:359来源:国知局
一种基于SQL的快速BOM展开方法与流程

本申请属于产品研发、制造、成本信息化管理,特别涉及一种基于sql的快速bom展开方法。


背景技术:

1、在复杂产品研发制造过程中,经常需要将多层级的bom展开为无层级的清单,以便进行原材料采购、成本计算等。

2、例如图1,将左侧树型的bom转换为右侧的清单;

3、其中物料的总数量为各分支按构型累乘数之和。如上图中物料e总数量38是a→e(1×6=6)、a→b→e(1×2×8=16)、a→c→e(1×1×4=4)、a→b→d→e(1×2×2×3=12)四个分支数量之和。

4、目前常见的bom展开算法主要有两类:

5、第一类是基于pl/sql或其他编程语言通过递归或低层码实现bom展开。该类算法效率偏低,展开5000节点的bom需约3分钟。且不能直接计算单个物料的数量,需把整个构型树完全展开后再从中获取指定物料数量。同时该算法针对不同应用场景对程序进行更改的难度较高,且需较高的开发权限。

6、第二类是基于数据库递归with功能实现bom展开(此功能只有较高版本的数据库才支持)。这类算法对于简单的父子表效率较高,但若数据源需多表联合查询时效率有明显降低。该算法同样不能直接计算单个物料的数量,需把整个构型树完全展开后再从中获取指定物料数量。


技术实现思路

1、为了解决上述问题,本申请提供了一种基于sql的快速bom展开方法,包括:

2、步骤s1;通过数据库在产品构型树上查询待查询物料的装配链路及各层数量;

3、步骤s2:计算每个所述装配链路中待查询物料的单链数量;

4、步骤s3:将各个所述装配链路的单链数量求和得到总数量。

5、优选的是,在步骤s1之前,在数据库中提取所述产品构型树,并通过数据库将所述产品构型树同时在产品构型树中标记叶节点、父子节点。

6、优选的是,在步骤s1中数据库通过从子到父的层级查询方式获得待查询物料的装配链路及各层数量。

7、优选的是,所述待查询物料的种类包括一种、两种、或者多种。

8、优选的是,所述单链数量通过对数运算和幂运算的方式将累乘转换为累加计算得到。所述对数运算和幂运算的方式为:将各层级的待查询物料进行累乘计算,再将累乘计算转换成累加便于系统计算。

9、本申请的优点包括:本算法具有速度快、拓展性强、权限需求低等优点,具体如下:

10、1)效率

11、能快速完成bom展开,完整展开5000节点的bom只需3秒左右时间,充分利用了数据库的检索功能,能够快速对待查询的物料进行检索,避免了算法在计算的过程中对待查询的物料检索上浪费大量时间。对单个物料可直接计算数量,效率进一步提升。

12、2)拓展

13、完全基于sql,具有较强的扩展性,可针对不同应用场景灵活增加查询和筛选条件。

14、3)权限

15、只需要数据库查询权限,可通过只读用户等方式将数据表提供给看板等外部系统或软件使用,不用担心系统数据表、存储过程的内容被更改。

16、本算法在制造业信息化领域有广泛的适用性,可用于采购需求计算、自制需求计算、成本计算、工时计算、工艺装备统计、加工周期评估等方面。



技术特征:

1.一种基于sql的快速bom展开方法,其特征在于,包括:

2.如权利要求1所述的基于sql的快速bom展开方法,其特征在于,包括:

3.如权利要求1所述的基于sql的快速bom展开方法,其特征在于,包括:

4.如权利要求1所述的基于sql的快速bom展开方法,其特征在于,包括:

5.如权利要求1所述的基于sql的快速bom展开方法,其特征在于,包括:


技术总结
本申请属于产品研发、制造、成本信息化管理,特别涉及一种基于SQL的快速BOM展开方法,步骤S1;通过数据库在产品构型树上查询待查询物料的装配链路及各层数量;步骤S2:计算每个所述装配链路中待查询物料的单链数量;步骤S3:将各个所述装配链路的单链数量求和得到总数量,本申请能快速完成BOM展开,完整展开5000节点的BOM只需3秒左右时间,充分利用了数据库的检索功能,能够快速对待查询的物料进行检索,避免了算法在计算的过程中对待查询的物料检索上浪费大量时间。对单个物料可直接计算数量,效率进一步提升。

技术研发人员:姚敦显
受保护的技术使用者:中国航空工业集团公司雷华电子技术研究所
技术研发日:
技术公布日:2024/1/12
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1