Files
GateDge2023_ljy/02.珠海市供水有限公司/ZHSW/STK_MisDelivery/sql/更新其他出库单参考单价_V1.sql

213 lines
8.9 KiB
MySQL
Raw Normal View History

2024-04-22 09:39:19 +08:00
/********************************取上游单据start*****************************************/
2024-04-10 10:39:04 +08:00
SELECT t0e.FMATERIALID
,(CASE t0e_lk.FSTABLENAME
2024-04-22 09:39:19 +08:00
WHEN 'T_STK_MISDELIVERYENTRY' THEN t1.FPRICE --退-
WHEN 'T_STK_INSTOCKENTRY' THEN t2.FPRICE -- -
WHEN 'T_STK_STKTRANSFERINENTRY1' THEN t3.FPRICE -- -
2024-04-10 10:39:04 +08:00
ELSE 0
END) AS 'newReferPrice'
,(CASE t0e_lk.FSTABLENAME
2024-04-22 09:39:19 +08:00
WHEN 'T_STK_MISDELIVERYENTRY' THEN '源_其他出库单:'+ t1.FBILLNO
WHEN 'T_STK_INSTOCKENTRY' THEN '源_采购入库单:'+ t2.FBILLNO
WHEN 'T_STK_STKTRANSFERINENTRY1' THEN (CASE t3.FPRICE WHEN 0 THEN '' ELSE '源_分步式调入单:'+ t3.FBILLNO END)
2024-04-10 10:39:04 +08:00
ELSE ''
END) AS 'newExplain'
,t0.FBILLNO
,t0.FDATE
,YEAR(t0.FDATE) * 100 + MONTH(t0.FDATE) AS DateNum
,t0e.FSTOCKID
,t0e.FID
,t0e.FENTRYID
,t0e_lk.FSTABLENAME
,t4.FMASTERID
,t4i.FINVPTYID
,t4i.FISAFFECTCOST
,t4i.FISENABLE
INTO #TMP_HAS_PARENT_MIS
FROM T_STK_MISDELIVERY t0
INNER JOIN T_STK_MISDELIVERYENTRY t0e on t0.FID = t0e.FID
LEFT JOIN T_STK_MISDELIVERYENTRY_LK t0e_lk on t0e.FENTRYID = t0e_lk.FENTRYID
LEFT JOIN (
SELECT t1.FBILLNO,t1e.FPRICE
,t1.FID,t1e.FENTRYID
2024-04-22 09:39:19 +08:00
FROM T_STK_MISDELIVERY t1 --
2024-04-10 10:39:04 +08:00
INNER JOIN T_STK_MISDELIVERYENTRY t1e on t1.FID = t1e.FID
--AND (t1e.FID = t0e_lk.FSBILLID AND t1e.FENTRYID = t0e_lk.FSID AND t0e_lk.FSTABLENAME = 'T_STK_MISDELIVERYENTRY')
) t1 ON (t1.FID = t0e_lk.FSBILLID AND t1.FENTRYID = t0e_lk.FSID AND t0e_lk.FSTABLENAME = 'T_STK_MISDELIVERYENTRY')
LEFT JOIN (
SELECT t2.FBILLNO,t2e.FPRICE
,t2.FID,t2e.FENTRYID
2024-04-22 09:39:19 +08:00
FROM T_STK_INSTOCK t2 --
2024-04-10 10:39:04 +08:00
INNER JOIN T_STK_INSTOCKENTRY_F t2e on t2.FID = t2e.FID
--AND (t2e.FID = t0e_lk.FSBILLID AND t2e.FENTRYID = t0e_lk.FSID AND t0e_lk.FSTABLENAME = 'T_STK_INSTOCKENTRY')
) t2 ON (t2.FID = t0e_lk.FSBILLID AND t2.FENTRYID = t0e_lk.FSID AND t0e_lk.FSTABLENAME = 'T_STK_INSTOCKENTRY')
LEFT JOIN (
2024-04-22 09:39:19 +08:00
SELECT t3.FBILLNO
-- ,(CASE LTRIM(RTRIM(t3e.FReferPrice)) WHEN '' THEN 0 ELSE CONVERT(decimal(23,6) ,t3e.FReferPrice) END) AS FPRICE
,t3e.F_GAT_DECIMAL AS FPRICE
2024-04-10 10:39:04 +08:00
,t3.FID,t3e.FENTRYID
2024-04-22 09:39:19 +08:00
FROM T_STK_STKTRANSFERIN t3 --
2024-04-10 10:39:04 +08:00
INNER JOIN T_STK_STKTRANSFERINENTRY t3e on t3.FID = t3e.FID
--AND (t3e.FID = t0e_lk.FSBILLID AND t3e.FENTRYID = t0e_lk.FSID AND t0e_lk.FSTABLENAME = 'T_STK_STKTRANSFERINENTRY1')
) t3 ON (t3.FID = t0e_lk.FSBILLID AND t3.FENTRYID = t0e_lk.FSID AND t0e_lk.FSTABLENAME = 'T_STK_STKTRANSFERINENTRY1')
INNER JOIN T_BD_MATERIAL t4 on t4.FMATERIALID = t0e.FMATERIALID
INNER JOIN T_BD_MATERIALINVPTY t4i on t0e.FMATERIALID = t4i.FMATERIALID AND t4i.FINVPTYID = 10001 --AND t4i.FISENABLE = 1
WHERE 1 = 1
AND t0.FSTOCKORGID = 101542
2024-04-22 09:39:19 +08:00
-- AND t0.FDATE >= '2024-01-01 00:00:00.000'
AND t0.FDATE BETWEEN '2024-01-01 00:00:00.000' AND '2024-03-31 00:00:00.000'
/********************************取上游单据end*****************************************/
/***********************************存货收发结存start***************************************************/
2024-04-10 10:39:04 +08:00
SELECT t0.FID,t0.FENTRYID,t0.FDATE,t0.FBILLNO,t0.FMASTERID
,t0.FMATERIALID,t0.FSTOCKID,t0.FINVPTYID,t0.FISAFFECTCOST,t0.FISENABLE
2024-04-22 09:39:19 +08:00
,ISNULL((CASE t0.newReferPrice WHEN 0
2024-04-10 10:39:04 +08:00
THEN (CASE WHEN t0.FISAFFECTCOST = 1 AND t0.FISENABLE = 1 THEN t2.FDATE ELSE t3.FDATE END)
ELSE t0.newExplain
2024-04-22 09:39:19 +08:00
END),'') AS 'newExplain'
,ISNULL((CASE t0.newReferPrice WHEN 0 THEN
2024-04-10 10:39:04 +08:00
(CASE WHEN t0.FISAFFECTCOST = 1 AND t0.FISENABLE = 1
THEN t2.PRICE
ELSE (CASE WHEN t3.FQTY <> 0 THEN ROUND(t3.FAMOUNT/t3.FQTY,6) ELSE 0 END)
END)
ELSE t0.newReferPrice
2024-04-22 09:39:19 +08:00
END),0) AS 'newReferPrice'
INTO #TMP_结存单价_END_LIST
2024-04-10 10:39:04 +08:00
FROM #TMP_HAS_PARENT_MIS t0
OUTER APPLY(
SELECT TOP 1 tt1.FDATE
,(CASE WHEN tt1.FQTY <> 0 THEN ROUND(tt1.FAMOUNT/tt1.FQTY,6) ELSE 0 END) AS PRICE
FROM V_MATERIAL_INIVSTOCKDIMENSION tt1
WHERE 1 = 1
AND t0.FMASTERID = tt1.FMASTERID
AND t0.FSTOCKID = tt1.FSTOCKID
AND tt1.DateNum <= t0.DateNum
AND (t0.FISENABLE = 1 AND t0.FISAFFECTCOST = 1)
2024-04-22 09:39:19 +08:00
AND t0.newReferPrice = 0
2024-04-10 10:39:04 +08:00
AND tt1.FQTY > 0
ORDER BY tt1.FYEAR DESC,tt1.FPERIOD DESC
) t2
OUTER APPLY (
SELECT TOP 1 tt2.FYEAR,tt2.FPERIOD
,CONVERT(nvarchar(10),FYEAR) + '.' + CONVERT(nvarchar(10),FPERIOD) AS FDATE
,SUM(tt2.FAMOUNT) AS FAMOUNT,SUM(tt2.FQTY) AS FQTY
FROM V_MATERIAL_INIVSTOCKDIMENSION tt2
WHERE 1 = 1
AND t0.FMASTERID = tt2.FMASTERID
AND tt2.DateNum <= t0.DateNum
AND (t0.FISENABLE = 0 OR t0.FISAFFECTCOST = 0)
2024-04-22 09:39:19 +08:00
AND t0.newReferPrice = 0
2024-04-10 10:39:04 +08:00
GROUP BY tt2.FYEAR,tt2.FPERIOD
HAVING SUM(tt2.FQTY) > 0
ORDER BY tt2.FYEAR DESC,tt2.FPERIOD DESC
) t3
2024-04-22 09:39:19 +08:00
--CREATE INDEX #TMP_结存单价_END_LIST_INDEX_FDATE ON #TMP_结存单价_END_LIST(FDATE)
/*****************************************存货收发结存end***********************************************/
/*****************************************合同单价、采购入库单start**********************************************/
2024-04-10 10:39:04 +08:00
SELECT t0.FBILLNO,t0.FID,t0.FENTRYID,t0.FDATE,t0.FMASTERID
,t0.FMATERIALID,t0.FSTOCKID,t0.FINVPTYID,t0.FISAFFECTCOST
,ISNULL((CASE WHEN t0.newReferPrice = 0
THEN (CASE WHEN t0.FISAFFECTCOST = 1 AND t0.FISENABLE = 1
THEN (CASE WHEN t1.FMATERIALID IS NOT NULL THEN t1.FPRICE ELSE t2.FPRICE END)
ELSE (CASE WHEN t2.FMATERIALID IS NOT NULL THEN t2.FPRICE ELSE t1.FPRICE END)
END)
ELSE t0.newReferPrice
END),0) AS 'newReferPrice'
,ISNULL((CASE WHEN t0.newReferPrice = 0
THEN (CASE WHEN t0.FISAFFECTCOST = 1 AND t0.FISENABLE = 1
2024-04-22 09:39:19 +08:00
THEN (CASE WHEN t1.FMATERIALID IS NOT NULL THEN '取采购入库单单价,单据:'+t1.FBILLNO ELSE '取合同价,合同号为:'+t2.FBILLNO END)
ELSE (CASE WHEN t2.FMATERIALID IS NOT NULL THEN '取合同价,合同号为:'+t2.FBILLNO ELSE '取采购入库单单价,单据:'+t1.FBILLNO END)
2024-04-10 10:39:04 +08:00
END)
ELSE t0.newExplain
2024-04-22 09:39:19 +08:00
END),'没有找到价格') AS 'newExplain'
INTO #TMP_结存单价_END_LIST_1
FROM #TMP_结存单价_END_LIST t0
2024-04-10 10:39:04 +08:00
OUTER APPLY (
SELECT TOP 1 tt0.FBILLNO,tt0e.FMATERIALID,tt0e.FSTOCKID
,tt0e_f.FPRICE,tt0e_f.FCOSTPRICE
2024-04-22 09:39:19 +08:00
FROM T_STK_INSTOCK tt0 --
2024-04-10 10:39:04 +08:00
INNER JOIN T_STK_INSTOCKENTRY tt0e on tt0.FID = tt0e.FID
INNER JOIN T_STK_INSTOCKENTRY_F tt0e_f on tt0e.FENTRYID = tt0e_f.FENTRYID
WHERE
tt0.FDOCUMENTSTATUS = 'C'
AND tt0.FCANCELSTATUS = 'A'
AND tt0.FSTOCKORGID = 101542
AND (tt0e_f.FPRICE != 0 OR tt0e_f.FCOSTPRICE <> 0)
AND t0.FMATERIALID = tt0e.FMATERIALID AND tt0e.FSTOCKID = t0.FSTOCKID
AND DATEDIFF(DAY,tt0.FDATE, t0.FDATE) > -1
ORDER BY tt0.FDATE DESC
) t1
2024-04-22 09:39:19 +08:00
LEFT JOIN (
2024-04-10 10:39:04 +08:00
SELECT
tt0e.F_QNV_BASE1 AS FMATERIALID
2024-04-22 09:39:19 +08:00
--,tt0e.F_QNV_DECIMAL3 AS FPRICE--
--,tt0e.F_QNV_DECIMAL1 AS FPRICE--
,tt0e.F_QNV_PRICE AS FPRICE--
2024-04-10 10:39:04 +08:00
,tt0.F_QNV_TEXT2 AS FBILLNO
2024-04-22 09:39:19 +08:00
,tt1.FMASTERID
,ROW_NUMBER() OVER (PARTITION BY tt1.FMASTERID ORDER BY F_QNV_DATE2 DESC, tt1.FUSEORGID DESC) 'RN'
FROM QNV_t_Cust_Entry100003 tt0 --
INNER JOIN QNV_t_Cust_Entry100004 tt0e on tt0.FID = tt0e.FID
INNER JOIN T_BD_MATERIAL tt1 on tt1.FMATERIALID = tt0e.F_QNV_BASE1
2024-04-10 10:39:04 +08:00
WHERE 1 = 1
AND tt0.FDOCUMENTSTATUS = 'C'
2024-04-22 09:39:19 +08:00
AND tt0e.F_QNV_PRICE != 0
) t2 on t0.FMASTERID = t2.FMASTERID AND t2.RN = 1
/*****************************************合同单价、采购入库单end**********************************************/
2024-04-10 10:39:04 +08:00
SELECT t0.*
2024-04-22 09:39:19 +08:00
,t1e.FReferPrice
,t1e.FReferAmount
,t1e.FExplain
,t2.FNUMBER
,t2.F_QNV_Combo
FROM #TMP_结存单价_END_LIST_1 t0
2024-04-10 10:39:04 +08:00
INNER JOIN T_STK_MISDELIVERYENTRY t1e on t0.FENTRYID = t1e.FENTRYID
2024-04-22 09:39:19 +08:00
INNER JOIN T_BD_MATERIAL t2 on t1e.FMATERIALID = t2.FMATERIALID
-- INNER JOIN T_STK_INSTOCK t3 on CHARINDEX(t3.FBILLNO ,t1e.FEXPLAIN) = 1--采购入库
-- INNER JOIN T_STK_INSTOCKENTRY t3e on t3.FID = t3e.FID
WHERE 1 = 1
AND newReferPrice != 0
-- AND newExplain != '没有找到价格'
2024-04-10 10:39:04 +08:00
--AND t0.fbillno = 'QTCK074080'
2024-04-22 09:39:19 +08:00
--AND newExplain = '没有找到价格'
--AND t0.fbillno = 'QTCK074080'
-- UPDATE t0e SET t0e.FReferPrice = t1.newReferPrice
-- ,t0e.FReferAmount = t1.newReferPrice * t0e.FQTY
-- ,t0e.FExplain = t1.newExplain
-- FROM T_STK_MISDELIVERYENTRY t0e
-- INNER JOIN #TMP_结存单价_END_LIST_1 t1 on t0e.FENTRYID = t1.FENTRYID
-- WHERE t1.newReferPrice != 0
MERGE INTO T_STK_MISDELIVERYENTRY t0e USING (
SELECT t1.FID
,t1.FENTRYID
,t1.newReferPrice
,t1.newExplain
FROM TMP_结存单价_END_LIST_1 t1
) t1 ON (t0e.FENTRYID = t1.FENTRYID)
WHEN MATCHED THEN UPDATE SET
t0e.FReferPrice = t1.newReferPrice
,t0e.FReferAmount = t1.newReferPrice * t0e.FQTY
,t0e.FExplain = t1.newExplain;
-- UPDATE t0 SET t0.F_GAT_DECIMAL1 = t1.newTotalReferAmount
-- FROM T_STK_MISDELIVERY t0
-- INNER JOIN (
-- SELECT SUM(t0e.FReferAmount) AS newTotalReferAmount,t0.FID
-- FROM #TMP_结存单价_END_LIST_1 t0
-- INNER JOIN T_STK_MISDELIVERYENTRY t0e on t0e.FID = t0.FID
-- WHERE 1 = 1
-- AND t0.newReferPrice != 0
-- -- AND t0.FSTOCKORGID = 101542
-- -- AND t0.FDATE >= '2024-04-01 00:00:00.000'
-- GROUP BY t0.FID
-- ) t1 on t0.FID = t1.FID
2024-04-10 10:39:04 +08:00
DROP TABLE #TMP_HAS_PARENT_MIS
2024-04-22 09:39:19 +08:00
DROP TABLE #TMP_结存单价_END_LIST
DROP TABLE #TMP_结存单价_END_LIST_1