lxh168
--1.更新表信息
  --嵌套EXISTS最内层大范围筛选修改日期的"FID"信息
  --次内层进一步筛选符合调拨单的"FID"信息
  --嵌套外层筛选符合"FID"条件的分录内码"FENTRYID"信息

UPDATE A set a.FAMOUNT_LC=0,a.FPRICE=0
FROM     T_SAL_OUTSTOCKENTRY_C A
WHERE EXISTS(SELECT FENTRYID 
            FROM T_SAL_OUTSTOCKENTRY B 
            WHERE A.FENTRYID=B.FENTRYID 
                AND EXISTS(SELECT FID 
                           FROM T_SAL_OUTSTOCKENTRY_R C 
                           WHERE C.FID=B.FID AND C.FSRCBILLNO LIKE \'CA%\'
                                AND EXISTS(SELECT FID 
                                           FROM T_SAL_OUTSTOCK D 
                                           WHERE D.FID=C.FID AND CONVERT(VARCHAR(10),D.FDATE,120)>=\'2018-07-01\'
                                           ) 
                           )
             )
--2.更新表信息
--方法一:
UPDATE B set B.FCOSTAMOUNT=0,B.FCOSTPRICE=0
FROM T_SAL_OUTSTOCK A
  LEFT JOIN T_SAL_OUTSTOCKENTRY_F B ON B.FID=A.FID
WHERE CONVERT(VARCHAR(10),A.FDATE,120)>=\'2018-07-01\' --A.FBILLNO=\'JC1807-0322\'
AND ISNULL(B.FCOSTAMOUNT,0)<>0
AND EXISTS(SELECT FID FROM T_SAL_OUTSTOCKENTRY_R C WHERE A.FID=C.FID AND C.FSRCBILLNO LIKE \'CA%\')
--方法二:
UPDATE A SET A.FCOSTAMOUNT=0,A.FCOSTPRICE=0
FROM T_SAL_OUTSTOCKENTRY_F A
WHERE EXISTS(SELECT B.FID 
            FROM T_SAL_OUTSTOCKENTRY_R B 
            WHERE A.FID=B.FID AND B.FSRCBILLNO LIKE \'CA%\'
                 AND EXISTS(SELECT C.FID 
                            FROM T_SAL_OUTSTOCK C 
                            WHERE C.FID=B.FID 
                                AND CONVERT(VARCHAR(10),C.FDATE,120)>=\'2018-07-01\'
                 )
            ) AND ISNULL(A.FCOSTAMOUNT,0)<>0 

 

分类:

技术点:

相关文章:

  • 2021-11-18
  • 2021-11-18
  • 2021-11-18
  • 2021-11-18
  • 2021-11-18
  • 2021-04-22
  • 2021-11-23
  • 2021-06-28
猜你喜欢
  • 2021-11-18
  • 2021-11-18
  • 2021-11-18
  • 2021-11-18
  • 2021-11-18
  • 2021-11-18
  • 2021-11-18
相关资源
相似解决方案