2019.06.28 MERGE INTO memo

--保存主表
MERGE INTO dbo.DeliveryReceiving AS t
USING @ReceiveMainDt AS s
ON t.Id=s.id
WHEN MATCHED
THEN UPDATE SET --一行五个字段
t.Amount=s.Amount,t.OperId=s.OperId,t.OperDate=GETDATE(),t.OperBranchId=s.OperBranchId
WHEN NOT MATCHED BY TARGET
THEN INSERT (Id,[Type],IOFlag,BranchId,DCBranchId,VoucherId,Amount,OperId,OperDate,OperBranchId,Memo)
VALUES
(s.id,s.[Type],s.IOFlag,s.BranchId,s.DCBranchId,s.VoucherId,s.Amount,s.OperId,GETDATE(),s.OperBranchId,s.Memo);
--保存明细表
MERGE INTO dbo.DeliveryReceivingEntry AS t
USING @ReceiveDetailDt AS s
ON t.SheetId=s.SheetId AND t.FlowId=s.FlowID
WHEN MATCHED
THEN UPDATE SET --匹配时更新
t.ReceiveQty=s.ReceiveQty,t.SubAmt=s.SubAmt,t.DetailsOperDate=GETDATE()
WHEN NOT MATCHED BY TARGET
THEN INSERT(SheetId,Sequence,ItemId,Barcode,UnitId,ReceiveQty,UnitFactor,ActualQty,ActualPrice,RetailPrice,SubAmt,TaxRate,Memo,ShelfId,BatchNo,ValidityDate,DetailsOperDate)
VALUES
(s.SheetId,s.Sequence,s.ItemId,s.Barcode,s.UnitId,s.ReceiveQty,s.UnitFactor,s.ActualQty,s.ActualPrice,s.RetailPrice,s.SubAmt,s.TaxRate,s.Memo,s.ShelfId,s.BatchNo,s.ValidityDate,GETDATE())
WHEN NOT MATCHED BY SOURCE AND T.SheetId=@Id
THEN DELETE ;

Guess you like

Origin www.cnblogs.com/kafeibuhuizui/p/11103777.html