zhouhuan324 2013-07-04 09:07
浏览 1078

SQL里递归结果如何和其他表进行关联

我这里有一个退料,主要是退半成品,和一个领料,主要是领半成品下面的物料的一个SQL语句:SELECT tf1.REM,tf1.IJ_NO,tf1.PRD_NO,tf1.ID_NO,tf1.qty ,tf2.FL_NO,tf2.PRD_NO,tf2. qty

FROM TF_IJ tf1
LEFT JOIN TF_FL tf2 ON tf2.REM=tf1.REM AND tf2.ITM=tf1.ITM

WHERE tf1.REM!=''AND tf1.PRD_NO LIKE '1010%' AND tf1.REM='MO121001706'AND tf1.PRD_NO= '1010300125'
结果如下:
REM IJ_NO PRD_NO ID_NO qty FL_NO PRD_NO qty
MO121001706 WI130100106 1010300125 1010300125->A0 40 M7130600060 1030100163 300
然后我用递归查询出来了这个半成品下面的最终物料和单位用量(都递归过),语句如下:
WITH CTE(bom_no,prd_no,id_no,qty )
AS
(select bom_no,prd_no,id_no,qty from tf_bom WHERE BOM_NO='1010300125->A0'
UNION ALL

SELECT A.BOM_NO,A.PRD_NO,A.id_no,CAST((B.qty*A.QTY) as NUMERIC(28,8)) AS qty
FROM CTE B
INNER JOIN tf_bom A on A.bom_NO=B.id_no )
SELECT bom_no,prd_no,id_no,qty FROM CTE where not exists( select 1 from tf_bom where bom_NO=CTE.id_no)
递归的结果是:
bom_no prd_no id_no qty
POL111->A0 1020300223 1
POL111->A0 1020300132 1
1010100060-> 1020500024 1
然后我想要的结果是根据查出退料的半成品及退料数,根据递归结果,得出应该领的最终物料的物料号及数量,和实际领的物料号及数量进行比较,结果如下:
IJ_NO PRD_NO ID_NO qty 1010300125->A0的下层物料 1010300125->A0的最终物料 根据递归的标准用量乘以退料的半成品数 FL_NO PRD_NO qty
WI130100106 1010300125 1010300125->A0 40 POL111->A0 1020300223 1x40 M7130600060 1030100163 300
WI130100106 1010300125 1010300125->A0 40 POL111->A0 1020300132 1x40 M7130600060 1030100163 300
WI130100106 1010300125 1010300125->A0 40 1010100060-> 1020500024 1x40 M7130600060 1030100163 300

  • 写回答

0条回答

    报告相同问题?

    悬赏问题

    • ¥20 求数据集和代码#有偿答复
    • ¥15 关于下拉菜单选项关联的问题
    • ¥15 如何修改pca中的feature函数
    • ¥20 java-OJ-健康体检
    • ¥15 rs485的上拉下拉,不会对a-b<-200mv有影响吗,就是接受时,对判断逻辑0有影响吗
    • ¥15 使用phpstudy在云服务器上搭建个人网站
    • ¥15 应该如何判断含间隙的曲柄摇杆机构,轴与轴承是否发生了碰撞?
    • ¥15 vue3+express部署到nginx
    • ¥20 搭建pt1000三线制高精度测温电路
    • ¥15 使用Jdk8自带的算法,和Jdk11自带的加密结果会一样吗,不一样的话有什么解决方案,Jdk不能升级的情况