使用 PostgreSql 几天,我被其新颖的功能以及效率深深吸引,我非常喜欢她!然而 PostgreSql 较稳定的版本在8.0以前通常在Unix以及Linux系统下运行,让一些普通开发人员入门很难!而同时我发觉国内开发人员不怎么愿意与别人分享成功的经验,看来传统文化“绝技不外传”的影响力依然不可小看。BOM之算法虽然非什么绝技但确实难到一些开发人员,本人一直研究MRP,在国内外BBS以及网上还没有看见谁将MRP最核心的算法公布出来,而MRP核心的核心BOM之算法也不多见。而以PostgreSql 的扩展语言plpgsql撰写BOM算法我还没有在国内外的网站上看见过,现在我将完整的BOM算法公布出来,无阶层限制。当然更好的BOM算法还有,如最终报告实现树形结构的SQL算法。此算法待我有空再发布出来。
第一步,建立两个表。第一个表存放BOM结构数据,而另外一个表存放你查询一个产品BOM报告。
--BOM 数据存放表
CREATE TABLE bomib
(
ib010 char(12), --父阶
ib020 char(12), --子阶
ib030 int4 --用量
)WITH OIDS;
--测试数据
INSERT INTO BOMIB
VALUES('01OS620000GS',
'1040-1212212,
1);
INSERT INTO BOMIB
VALUES('01OS620000GS',
'1041-1212212,
1);
INSERT INTO BOMIB
VALUES('01OS620000GS',
'13OS-6200010,
1);
INSERT INTO BOMIB
V
第一步,建立两个表。第一个表存放BOM结构数据,而另外一个表存放你查询一个产品BOM报告。
--BOM 数据存放表
CREATE TABLE bomib
(
ib010 char(12), --父阶
ib020 char(12), --子阶
ib030 int4 --用量
)WITH OIDS;
--测试数据
INSERT INTO BOMIB
VALUES('01OS620000GS',
'1040-1212212,
1);
INSERT INTO BOMIB
VALUES('01OS620000GS',
'1041-1212212,
1);
INSERT INTO BOMIB
VALUES('01OS620000GS',
'13OS-6200010,
1);
INSERT INTO BOMIB
V