Project

General

Profile

Bug #4055 ยป PFILOUPDATEMDSTOCKINFO_20251210.sql

Tri Rizqiaty, 12/10/2025 03:23 PM

 
1
??ALTER PROCEDURE [dbo].[PFILOUPDATEMDSTOCKINFO]
2

3
(
4

5
	@MaterialID VARCHAR(20)
6

7
	,@Quantity DECIMAL(22,2)
8

9
	,@TotalPrice DECIMAL(20,2)
10

11
	,@DocType VARCHAR(20)
12

13
	,@UserID VARCHAR(20)
14

15
	,@CompanyID VARCHAR(20)
16

17
	,@LogisticArea VARCHAR(20)
18

19
	,@Warehouse VARCHAR(20)
20

21
	,@Storage VARCHAR(20)
22

23
	,@Bin VARCHAR(20)
24

25
	,@ReceiverLogisticArea VARCHAR(20)
26

27
	,@ReceiverWarehouse VARCHAR(20) 
28

29
	,@ReceiverStorage VARCHAR(20)
30

31
	,@ReceiverBin VARCHAR(20)
32

33
	,@DocIDRef VARCHAR(20)
34

35
	,@DocTypeRef VARCHAR(20)
36

37
	,@TransTypeRef VARCHAR(20)
38

39
	,@ItemFlow VARCHAR(50)
40

41
	,@StockStatus VARCHAR(20)
42

43
	,@DocStatus VARCHAR(20)
44

45
)
46

47
AS
48

49

50

51
--DECLARE @MaterialID VARCHAR(20) = '00000030'
52

53
--DECLARE @Quantity DECIMAL(22,2) = 10
54

55
--DECLARE @TotalPrice DECIMAL(20,2) = '0'
56

57
--DECLARE @DocType VARCHAR(20) = 'RCSP'
58

59
--DECLARE @UserID VARCHAR(20) = 'tri'
60

61
--DECLARE @CompanyID VARCHAR(20) = ''
62

63
--DECLARE @LogisticArea VARCHAR(20) = ''
64

65
--DECLARE @Warehouse VARCHAR(20) = '0001'
66

67
--DECLARE @Storage VARCHAR(20) = ''
68

69
--DECLARE @Bin VARCHAR(20) = 'F05032552'
70

71
--DECLARE @ReceiverLogisticArea VARCHAR(20) = ''
72

73
--DECLARE @ReceiverWarehouse VARCHAR(20) = ''
74

75
--DECLARE @ReceiverStorage VARCHAR(20) = ''
76

77
--DECLARE @ReceiverBin VARCHAR(20) = ''
78

79
--DECLARE @DocIDRef VARCHAR(20) = '00000359'
80

81
--DECLARE @DocTypeRef VARCHAR(20) = 'FLEX'
82

83
--DECLARE @TransTypeRef VARCHAR(20) = 'PRD'
84

85
--DECLARE @ItemFlow VARCHAR(50) = ''--'ISSU' --ISSU --RCPT
86

87
--DECLARE @StockStatus VARCHAR(20) = ''
88

89
--DECLARE @DocStatus VARCHAR(20) = '3' -- 1:Draft , 2:In Process, 3:Done, 4:Cancel
90

91

92

93
DECLARE @now VARCHAR(20) = dbo.fn_formatdatetime(GETDATE(), 'yyyymmdd')
94

95
DECLARE @now16 VARCHAR(20) = dbo.fn_formatdatetime(GETDATE(), 'yyyymmddhhnnss')
96

97

98

99
DECLARE @IsSuccess VARCHAR(250)
100

101

102

103
IF(@StockStatus = '')
104

105
BEGIN SET @StockStatus = '0001' END
106

107

108

109
IF(@Quantity < 0)
110

111
BEGIN SET @Quantity = @Quantity * -1 END
112

113

114

115
DECLARE @TblMAT4 TABLE
116

117
(
118

119
	[MaterialID] [VARCHAR](10) NOT NULL,
120

121
	[SeqID] [BIGINT] NOT NULL,
122

123
	[CompanyID] [VARCHAR](4) NOT NULL,
124

125
	[LogisticAreaID] [VARCHAR](10) NOT NULL,
126

127
	[Warehouse] [VARCHAR](20) NOT NULL,
128

129
	[Storage] [VARCHAR](10) NOT NULL,
130

131
	[Bin] [VARCHAR](10) NOT NULL,
132

133
	[StockStatus] [VARCHAR](10) NOT NULL,
134

135
	[GLValuationID] [VARCHAR](20) NULL,
136

137
	[Qty] DECIMAL(22,2) NULL,
138

139
	[TotalValuation] [DECIMAL](18, 2) NULL,
140

141
	[Sequence] [INT] NULL,
142

143
	[SerialNumber] [VARCHAR](50) NULL,
144

145
	[CreateBy] [VARCHAR](18) NULL,
146

147
	[CreateDate] [VARCHAR](14) NULL,
148

149
	[ChangeBy] [VARCHAR](18) NULL,
150

151
	[ChangeDate] [VARCHAR](14) NULL,
152

153
	[SORDID] [VARCHAR](18) NULL,
154

155
	[PRODID] [VARCHAR](18) NULL,
156

157
	[INTRID] [VARCHAR](18) NULL,
158

159
	[POID] [VARCHAR](18) NULL,
160

161
	[StockType] [VARCHAR](10) NULL,
162

163
	[DocIDRef] [VARCHAR](10) NULL,
164

165
	[DocTypeRef] [VARCHAR](10) NULL,
166

167
	[TransTypeRef] [VARCHAR](10) NULL
168

169
)
170

171
INSERT INTO @TblMAT4
172

173
SELECT [MaterialID]
174

175
      ,[SeqID]
176

177
      ,[CompanyID]
178

179
      ,[LogisticAreaID]
180

181
      ,[Warehouse]
182

183
      ,[Storage]
184

185
      ,[Bin]
186

187
      ,[StockStatus]
188

189
      ,[GLValuationID]
190

191
      ,[Qty]
192

193
      ,[TotalValuation]
194

195
      ,[Sequence]
196

197
      ,[SerialNumber]
198

199
      ,[CreateBy]
200

201
      ,[CreateDate]
202

203
      ,[ChangeBy]
204

205
      ,[ChangeDate]
206

207
      ,[SORDID]
208

209
      ,[PRODID]
210

211
      ,[INTRID]
212

213
      ,[POID]
214

215
      ,[StockType]
216

217
      ,[DocIDRef]
218

219
      ,[DocTypeRef]
220

221
      ,[TransTypeRef]
222

223
FROM dbo.PMDMAT0004
224

225
WHERE MaterialID = @MaterialID
226

227

228

229
DECLARE @MAP_MAT1 DECIMAL(22,2) = 0 
230

231
DECLARE @NewTotalValuation DECIMAL(22,2)
232

233
DECLARE @CekItemNotDoneAloc VARCHAR(20)
234

235
DECLARE @CekItemNotDone VARCHAR(20)
236

237
DECLARE @SisaQty DECIMAL(22,2) = @Quantity
238

239

240

241
IF(@DocType = 'GICU' AND (@DocStatus = '3' OR @DocStatus = '2') )
242

243
BEGIN
244

245
	SELECT @MAP_MAT1 = MAP FROM dbo.PMDMAT0001 WHERE MaterialID = @MaterialID
246

247

248

249
	IF(@DocIDRef <> '' AND @DocTypeRef <> '' AND @TransTypeRef <>'')		---- // jika doc ref dr sales order
250

251
	BEGIN
252

253

254

255
		DECLARE @SumMat4Aloc DECIMAL(22,2) = 0
256

257
		SELECT @SumMat4Aloc = SUM(Qty)	FROM @TblMAT4 
258

259
		WHERE MaterialID = @MaterialID AND DocIDRef = @DocIDRef AND DocTypeRef = @DocTypeRef AND TransTypeRef = @TransTypeRef AND Warehouse = @Warehouse --AND StockStatus = @StockStatus
260

261

262

263
		IF(@Quantity > @SumMat4Aloc)
264

265
		BEGIN
266

267
			SET @IsSuccess = 'OVERQTY'
268

269
		END
270

271
		ELSE
272

273
		BEGIN 
274

275

276

277
			DECLARE @QtyAlocateMAT4 DECIMAL(22,2) = 0
278

279
			DECLARE @c_materialidA VARCHAR(20)
280

281
			DECLARE @c_seqA VARCHAR(20)
282

283
			DECLARE @c_qtyA VARCHAR(20)
284

285
			DECLARE cur_mat4A CURSOR FOR (SELECT MaterialID, SeqID, Qty FROM @TblMAT4 WHERE MaterialID = @MaterialID
286

287
										AND DocIDRef = @DocIDRef AND DocTypeRef = @DocTypeRef AND TransTypeRef = @TransTypeRef AND Warehouse = @Warehouse) --AND StockStatus = @StockStatus )
288

289
			OPEN cur_mat4A
290

291
			FETCH cur_mat4A INTO @c_materialidA, @c_seqA, @c_qtyA
292

293
			WHILE @@Fetch_Status = 0
294

295
			BEGIN
296

297
			
298

299
				SET @QtyAlocateMAT4 = @c_qtyA
300

301
				
302

303
				IF(@SisaQty = 0)
304

305
				BEGIN
306

307
					BREAK
308

309
				END
310

311
				ELSE IF(@QtyAlocateMAT4 > @SisaQty)				----// case good issue sebagian(partial)
312

313
				BEGIN
314

315
					DECLARE @SisaQtyAlocateMAT4 DECIMAL(22,2) = 0
316

317
					SET @SisaQtyAlocateMAT4 = @QtyAlocateMAT4 - @SisaQty
318

319

320

321
					UPDATE dbo.PMDMAT0004					----// update quantity mat4
322

323
					SET Qty = @SisaQtyAlocateMAT4
324

325
						,TotalValuation = @SisaQtyAlocateMAT4 * @MAP_MAT1
326

327
						,ChangeBy = @UserID
328

329
						,ChangeDate = @now16
330

331
					--SELECT 'update qty mat4', @SisaQtyAlocateMAT4, * FROM dbo.PMDMAT0004
332

333
					WHERE MaterialID = @MaterialID
334

335
						AND DocIDRef = @DocIDRef 
336

337
						AND DocTypeRef = @DocTypeRef 
338

339
						AND TransTypeRef = @TransTypeRef
340

341
						AND Warehouse = @Warehouse 
342

343
						AND SeqID = @c_seqA
344

345
				
346

347
					DECLARE @MaxDocItemID DECIMAL(22,0)
348

349
					SELECT @MaxDocItemID = MAX(DocItemID)
350

351
					FROM dbo.PTRALLOCATION WITH(NOLOCK)
352

353
					WHERE DocNo = @DocIDRef
354

355

356

357
					UPDATE dbo.PTRALLOCATION					----// update quantity ptraloc
358

359
					SET StockAllocation = @SisaQtyAlocateMAT4
360

361
						,ChangeBy = @UserID
362

363
						,ChangeDate = @now16
364

365
					--SELECT  'udpate stock ptraloc', @SisaQtyAlocateMAT4, * FROM dbo.PTRALLOCATION WITH(NOLOCK)
366

367
					WHERE DocNo = @DocIDRef
368

369
						AND MaterialID = @MaterialID
370

371
						AND WareHouse = @Warehouse
372

373
						AND ItemStatus = '1'
374

375
						AND StockAllocation = @c_qtyA
376

377

378

379
					INSERT INTO PTRALLOCATION
380

381
					SELECT DISTINCT	[DocNo] 
382

383
					--SELECT DISTINCT 'add ptraloc', DocNo
384

385
						,CONVERT(VARCHAR(20),@MaxDocItemID + 1) AS [DocItemID]
386

387
						,@SisaQty AS StockAllocation
388

389
						,[WareHouse]
390

391
						,[Storage]
392

393
						,[Bin]
394

395
						,[TransferOrderRef]
396

397
						,[TransferOrderItem]
398

399
						,[PurchaseOrderRef]
400

401
						,[PurchaseOrderItem]
402

403
						,[ProductionOrderRef]
404

405
						,[ProductionOrderItem]
406

407
						,@UserID
408

409
						,@now16
410

411
						,@UserID
412

413
						,@now16
414

415
						,[MaterialID]
416

417
						,[StockType]
418

419
						,[MAP]
420

421
						,'2' AS ItemStatus				----// 2 = Done
422

423
						,[ItemType]
424

425
						,IsAllocated
426

427
					FROM dbo.PTRALLOCATION
428

429
					WHERE MaterialID = @MaterialID
430

431
						AND DocNo = @DocIDRef 
432

433
						AND Warehouse = @Warehouse 
434

435
						AND ItemStatus = '1'
436

437

438

439
					SET @IsSuccess = 'Y' 
440

441

442

443
					BREAK
444

445
				END
446

447
				ELSE IF(@SisaQty >= @QtyAlocateMAT4)
448

449
				BEGIN
450

451
					SET @SisaQtyAlocateMAT4 = 0
452

453
					SET @SisaQty = @SisaQty - @QtyAlocateMAT4
454

455

456

457
					DELETE FROM dbo.PMDMAT0004						--// delete mat4
458

459
					--SELECT 'delete mat4',* FROM dbo.PMDMAT0004 
460

461
					WHERE MaterialID = @MaterialID AND SeqID = @c_seqA
462

463

464

465
					UPDATE dbo.PTRALLOCATION						--// update ptraloc
466

467
					SET ItemStatus = '2'
468

469
						,ChangeBy = @UserID
470

471
						,ChangeDate = @now16
472

473
					--SELECT'update items status ptraloc jd 2', * FROM dbo.PTRALLOCATION
474

475
					WHERE MaterialID = @c_materialidA
476

477
						AND DocNo = @DocIDRef 
478

479
						AND Warehouse = @Warehouse
480

481
						AND ItemStatus = '1'
482

483
						AND StockAllocation = @c_qtyA	
484

485

486

487
					SET @IsSuccess = 'Y'
488

489
				END
490

491
				FETCH cur_mat4A INTO @c_materialidA, @c_seqA, @c_qtyA 
492

493
			END
494

495
			CLOSE cur_mat4A
496

497
			DEALLOCATE cur_mat4A
498

499

500

501
			SELECT @CekItemNotDoneALoc = COUNT(ItemStatus)
502

503
			FROM dbo.PTRALLOCATION 
504

505
			WHERE DocNo = @DocIDRef AND (ItemStatus = '0' OR ItemStatus = '1') AND MaterialID = @MaterialID
506

507
			
508

509
			IF(@CekItemNotDoneALoc = 0)
510

511
			BEGIN
512

513
				UPDATE dbo.PTRSALESITEMS
514

515
				SET ItemStatus = '2'
516

517
				WHERE DocNo = @DocIDRef AND Material = @MaterialID
518

519
			END
520

521
			ELSE
522

523
			BEGIN
524

525
				UPDATE dbo.PTRSALESITEMS
526

527
				SET ItemStatus = '1'
528

529
				WHERE DocNo = @DocIDRef AND Material = @MaterialID
530

531
			END
532

533

534

535
			SELECT @CekItemNotDone = COUNT(ItemStatus)
536

537
			FROM dbo.PTRALLOCATION 
538

539
			WHERE DocNo = @DocIDRef AND (ItemStatus = '0' OR ItemStatus = '1')
540

541

542

543
			IF(@CekItemNotDone = 0)
544

545
			BEGIN
546

547
				UPDATE dbo.PTRSALESHEADER
548

549
				SET ProcessStatus = 'C'
550

551
				WHERE DocNo = @DocIDRef 
552

553
			END
554

555

556

557

558

559
		END
560

561
	END
562

563
	ELSE
564

565
	BEGIN
566

567
		DECLARE @SumQtyMAT4 DECIMAL(22,2)
568

569
		SELECT @SumQtyMAT4 =  SUM(CONVERT(DECIMAL(22,2),Qty)) FROM @TblMAT4 
570

571
		WHERE (CompanyID = @CompanyID OR @CompanyID = '')
572

573
			AND (LogisticAreaID = @LogisticArea OR @LogisticArea = '')
574

575
			AND (Warehouse = @Warehouse OR @Warehouse = '')
576

577
			AND (Storage = @Storage OR @Storage = '')
578

579
			AND StockStatus = @StockStatus
580

581

582

583
		IF(@Quantity <= @SumQtyMAT4)
584

585
		BEGIN
586

587
			DECLARE @SisaQuantity DECIMAL(22,2) = @Quantity
588

589
			DECLARE @c_materialid VARCHAR(20)
590

591
			DECLARE @c_seq VARCHAR(20)
592

593
			DECLARE @c_qty VARCHAR(20)
594

595
			DECLARE cur_mat4 CURSOR FOR (SELECT MaterialID, SeqID, Qty FROM @TblMAT4 WHERE (CompanyID = @CompanyID OR @CompanyID = '') 
596

597
										AND (LogisticAreaID = @LogisticArea OR @LogisticArea = '') AND (Warehouse = @Warehouse OR @Warehouse = '')	
598

599
										AND (Storage = @Storage OR @Storage = '') AND (Storage = @Bin OR @Bin = '') AND StockStatus = @StockStatus)
600

601
			OPEN cur_mat4
602

603
			FETCH cur_mat4 INTO @c_materialid, @c_seq, @c_qty
604

605
			WHILE @@Fetch_Status = 0
606

607
			BEGIN
608

609
				IF(@SisaQuantity <= 0)
610

611
				BREAK
612

613

614

615
				DECLARE @SisaQtyMat4 DECIMAL(22,2)
616

617
				IF(@SisaQuantity > @c_qty)
618

619
				BEGIN 
620

621
					SET @SisaQtyMat4 = 0
622

623
					SET @SisaQuantity = @SisaQuantity - @c_qty
624

625
				END
626

627
				ELSE IF(@SisaQuantity < @c_qty)
628

629
				BEGIN  
630

631
					SET @SisaQtyMat4 = @c_qty - @SisaQuantity
632

633
					SET @SisaQuantity = @SisaQuantity - @c_qty	 
634

635
				END
636

637
				ELSE IF(@SisaQuantity = @c_qty)
638

639
				BEGIN 
640

641
					SET @SisaQtyMat4 = 0
642

643
					SET @SisaQuantity = @SisaQuantity - @c_qty
644

645
				END
646

647

648

649
				SET @NewTotalValuation = @MAP_MAT1 * @SisaQtyMat4
650

651
				UPDATE dbo.PMDMAT0004
652

653
				SET Qty = @SisaQtyMat4
654

655
					,TotalValuation = @NewTotalValuation
656

657
					,ChangeBy = @UserID
658

659
					,ChangeDate = @now16
660

661
				--SELECT * FROM dbo.PMDMAT0004
662

663
				WHERE MaterialID = @c_materialid
664

665
					AND SeqID = @c_seq
666

667

668

669
			FETCH cur_mat4 INTO @c_materialid, @c_seq, @c_qty 
670

671
			END
672

673
			CLOSE cur_mat4
674

675
			DEALLOCATE cur_mat4
676

677

678

679
			SET @IsSuccess = 'Y'
680

681
		END
682

683
		ELSE 
684

685
		BEGIN
686

687
			SET @IsSuccess = 'OVERQTY'
688

689
		END
690

691
	END
692

693
END
694

695

696

697

698

699
IF(@DocType = 'RCSP' AND (@DocStatus = '3')) -- OR @DocStatus = '2') )
700

701
BEGIN 
702

703
	DECLARE @IsMat4Exist VARCHAR(20) = ISNULL((SELECT COUNT(*) FROM @TblMAT4),0)
704

705
	SELECT @MAP_MAT1 = MAP FROM dbo.PMDMAT0001 WHERE MaterialID = @MaterialID
706

707

708

709
	DECLARE @TotalValuationAllMAT4 DECIMAL(22,2)
710

711
	DECLARE @TotalQtyAllMAT4 DECIMAL(22,2)
712

713
	DECLARE @TotalValuationAll DECIMAL(22,2)
714

715
	DECLARE @TotalQtyAll DECIMAL(22,2)
716

717
	DECLARE @NewMAP DECIMAL(22,2)
718

719

720

721
	IF(@IsMat4Exist <= 0)
722

723
	BEGIN
724

725
		INSERT INTO PMDMAT0004
726

727
		SELECT @MaterialID
728

729
			  ,'1'
730

731
			  ,@CompanyID
732

733
			  ,@LogisticArea
734

735
			  ,@Warehouse
736

737
			  ,@Storage
738

739
			  ,@Bin
740

741
			  ,@StockStatus --0001
742

743
			  ,''
744

745
			  ,@Quantity
746

747
			  ,@Quantity * @MAP_MAT1 AS TotalValuation
748

749
			  ,'1' AS [Sequence]
750

751
			  ,'' AS [SerialNumber]
752

753
			  ,@UserID
754

755
			  ,@now16
756

757
			  ,@UserID
758

759
			  ,@now16
760

761
			  ,'' AS [SORDID]
762

763
			  ,'' AS [PRODID]
764

765
			  ,'' AS [INTRID]
766

767
			  ,'' AS [POID]
768

769
			  ,'1' AS [StockType]
770

771
			  ,'' AS [DocIDRef]
772

773
			  ,'' AS [DocTypeRef]
774

775
			  ,'' AS [TransTypeRef]
776

777
		SET @IsSuccess = 'Y'
778

779
	END
780

781
	ELSE
782

783
	BEGIN 
784

785
		DECLARE @MaxSeqMat4Detail VARCHAR(20) = (SELECT MAX(SeqID) FROM @TblMAT4)
786

787

788

789
		DECLARE @IsMat4ExistDetail VARCHAR(20) 
790

791
		SELECT @IsMat4ExistDetail = COUNT(MaterialID)
792

793
		FROM @TblMAT4
794

795
		WHERE (CompanyID = @CompanyID OR @CompanyID = '')
796

797
			AND (LogisticAreaID = @LogisticArea OR @LogisticArea = '')
798

799
			AND (Warehouse = @Warehouse OR @Warehouse = '')
800

801
			AND (Storage = @Storage OR @Storage = '')
802

803
			AND (Storage = @Bin OR @Bin = '')
804

805
			AND (StockStatus = @StockStatus)
806

807

808

809
		DECLARE @PricePurSatuan DECIMAL(22,2) = 0
810

811
		SELECT @PricePurSatuan = (CONVERT(DECIMAL(22,2),TotAmount) / CONVERT(DECIMAL(22,0),MaterialQuantity))
812

813
		FROM dbo.PTRPURCHITEM
814

815
		WHERE DocNo = @DocIDRef
816

817
			AND Material = @MaterialID
818

819

820

821
		IF(@PricePurSatuan < 0)
822

823
		BEGIN
824

825
			SELECT @MAP_MAT1 = MAP FROM dbo.PMDMAT0001 WHERE MaterialID = @MaterialID
826

827
			SET @PricePurSatuan = @MAP_MAT1
828

829
		END
830

831

832

833
		SET @TotalValuationAllMAT4 = (SELECT SUM(CONVERT(DECIMAL(22,2),TotalValuation)) FROM @TblMAT4)
834

835
		SET @TotalQtyAllMAT4 = (SELECT SUM(CONVERT(DECIMAL(22,2),Qty)) FROM @TblMAT4)
836

837
		SET @TotalValuationAll = @TotalValuationAllMAT4 + (@PricePurSatuan * @Quantity) --@TotalPrice
838

839
		SET @TotalQtyAll = @TotalQtyAllMAT4 + @Quantity
840

841
		SET @NewMAP = @TotalValuationAll / @TotalQtyAll
842

843
		SET @NewTotalValuation = @NewMAP * @Quantity
844

845

846

847
		IF(@IsMat4ExistDetail <= 0)
848

849
		BEGIN
850

851
			IF(@DocIDRef <> '' AND @TransTypeRef = 'PRD')
852

853
			BEGIN
854

855
				
856

857
				INSERT INTO PMDMAT0004
858

859
				SELECT @MaterialID
860

861
					  ,@MaxSeqMat4Detail + 1
862

863
					  ,@CompanyID
864

865
					  ,@LogisticArea
866

867
					  ,@Warehouse
868

869
					  ,@Storage
870

871
					  ,@Bin
872

873
					  ,@StockStatus--'0001'
874

875
					  ,''
876

877
					  ,@Quantity
878

879
					  ,@NewTotalValuation AS TotalValuation
880

881
					  ,'1' AS [Sequence]
882

883
					  ,'' AS [SerialNumber]
884

885
					  ,@UserID
886

887
					  ,@now16
888

889
					  ,@UserID
890

891
					  ,@now16
892

893
					  ,'' AS [SORDID]
894

895
					  ,@DocIDRef AS [PRODID]
896

897
					  ,'' AS [INTRID]
898

899
					  ,'' AS [POID]
900

901
					  ,'1' AS [StockType]
902

903
					  ,@DocIDRef AS [DocIDRef]
904

905
					  ,@DocTypeRef AS [DocTypeRef]
906

907
					  ,@DocTypeRef AS [TransTypeRef]
908

909
			
910

911
				UPDATE dbo.PMDMAT0001
912

913
				SET MAP = @NewMAP
914

915
					,ChangeBy = @UserID
916

917
					,ChangeDate = @now16
918

919
				FROM dbo.PMDMAT0001
920

921
				WHERE MaterialID = @MaterialID
922

923
				
924

925
				UPDATE PMDMATWIP
926

927
				SET StockStatus = '0005'
928

929
					,ChangeBy = @UserID
930

931
					,ChangeDate = @now16
932

933
				--SELECT * FROM PMDMATWIP
934

935
				WHERE ProdID = @DocIDRef
936

937
					AND MaterialID = @MaterialID
938

939
				
940

941
				DECLARE @SPK_ VARCHAR(20)
942

943
				SELECT @SPK_ = SpkID
944

945
				FROM PMDMATWIP
946

947
				WHERE ProdID = @DocIDRef
948

949
					AND MaterialID = @MaterialID
950

951

952

953
				UPDATE PMDMATWIP
954

955
				SET DocStatus = '4'
956

957
					,StockStatus = '0005'
958

959
					,ChangeBy = @UserID
960

961
					,ChangeDate = @now16
962

963
				--SELECT * FROM PMDMATWIP
964

965
				WHERE ProdID = @SPK_
966

967
					AND MaterialID = @MaterialID 
968

969

970

971
				UPDATE PTRPRODUCTIONITEM
972

973
				SET Status = '2'
974

975
					,ChangeBy = @UserID
976

977
					,ChangeDate = @now16
978

979
				--SELECT * FROM PTRPRODUCTIONITEM
980

981
				WHERE DocNo = @DocIDRef
982

983
					AND FlowType = 'RCPT'
984

985
				
986

987
				UPDATE PTRPRODUCTIONHEAD
988

989
				SET DocStatus = '4'
990

991
					,ProcessStatus = 'C'
992

993
					,ChangeBy = @UserID
994

995
					,ChangeDate = @now16
996

997
				--SELECT * FROM PTRPRODUCTIONHEAD
998

999
				WHERE DocNo = @SPK_
1000

1001

1002

1003
				UPDATE PTRPRODUCTIONITEM
1004

1005
				SET Status = '2'
1006

1007
					,ChangeBy = @UserID
1008

1009
					,ChangeDate = @now16
1010

1011
				--SELECT * FROM PTRPRODUCTIONITEM
1012

1013
				WHERE DocNo = @SPK_
1014

1015
					AND FlowType = 'RCPT'
1016

1017

1018

1019
				SET @IsSuccess = 'Y'
1020

1021
			END
1022

1023
			ELSE
1024

1025
			BEGIN
1026

1027
				INSERT INTO PMDMAT0004
1028

1029
				SELECT @MaterialID
1030

1031
					  ,@MaxSeqMat4Detail + 1
1032

1033
					  ,@CompanyID
1034

1035
					  ,@LogisticArea
1036

1037
					  ,@Warehouse
1038

1039
					  ,@Storage
1040

1041
					  ,@Bin
1042

1043
					  ,@StockStatus--'0001'
1044

1045
					  ,''
1046

1047
					  ,@Quantity
1048

1049
					  ,@NewTotalValuation AS TotalValuation
1050

1051
					  ,'1' AS [Sequence]
1052

1053
					  ,'' AS [SerialNumber]
1054

1055
					  ,@UserID
1056

1057
					  ,@now16
1058

1059
					  ,@UserID
1060

1061
					  ,@now16
1062

1063
					  ,'' AS [SORDID]
1064

1065
					  ,'' AS [PRODID]
1066

1067
					  ,'' AS [INTRID]
1068

1069
					  ,'' AS [POID]
1070

1071
					  ,'1' AS [StockType]
1072

1073
					  ,'' AS [DocIDRef]
1074

1075
					  ,'' AS [DocTypeRef]
1076

1077
					  ,'' AS [TransTypeRef]
1078

1079
			
1080

1081
				UPDATE dbo.PMDMAT0001
1082

1083
				SET MAP = @NewMAP
1084

1085
					,ChangeBy = @UserID
1086

1087
					,ChangeDate = @now16
1088

1089
				FROM dbo.PMDMAT0001
1090

1091
				WHERE MaterialID = @MaterialID
1092

1093
				SET @IsSuccess = 'Y'
1094

1095
			END
1096

1097
		END
1098

1099
		ELSE
1100

1101
		BEGIN
1102

1103
			SET @TotalValuationAllMAT4 = (SELECT SUM(CONVERT(DECIMAL(22,2),TotalValuation)) FROM @TblMAT4)
1104

1105
			SET @TotalQtyAllMAT4 = (SELECT SUM(CONVERT(DECIMAL(22,2),Qty)) FROM @TblMAT4)
1106

1107
			SET @TotalValuationAll = @TotalValuationAllMAT4 + @TotalPrice
1108

1109
			SET @TotalQtyAll = @TotalQtyAllMAT4 + @Quantity
1110

1111
			SET @NewMAP = @TotalValuationAll / @TotalQtyAll
1112

1113
			
1114

1115
			DECLARE @MinSeqMat4 VARCHAR(20)
1116

1117
			SELECT @MinSeqMat4 = MIN(SeqID)
1118

1119
			FROM @TblMAT4
1120

1121
			WHERE (CompanyID = @CompanyID OR @CompanyID = '')
1122

1123
				AND (LogisticAreaID = @LogisticArea OR @LogisticArea = '')
1124

1125
				AND (Warehouse = @Warehouse OR @Warehouse = '')
1126

1127
				AND (Storage = @Storage OR @Storage = '')
1128

1129
				AND (Storage = @Bin OR @Bin = '')
1130

1131
				AND (StockStatus = @StockStatus)
1132

1133
			
1134

1135
			DECLARE @NewQty DECIMAL(22,2)
1136

1137
			SELECT @NewQty = CONVERT(DECIMAL(22,2),Qty) + @Quantity
1138

1139
				,@NewTotalValuation = (CONVERT(DECIMAL(22,2),Qty) + @Quantity) * @NewMAP
1140

1141
			FROM @TblMAT4
1142

1143
			WHERE (CompanyID = @CompanyID OR @CompanyID = '')
1144

1145
				AND (LogisticAreaID = @LogisticArea OR @LogisticArea = '')
1146

1147
				AND (Warehouse = @Warehouse OR @Warehouse = '')
1148

1149
				AND (Storage = @Storage OR @Storage = '')
1150

1151
				AND (Storage = @Bin OR @Bin = '')
1152

1153
				AND (SeqID = @MinSeqMat4)
1154

1155

1156

1157
			IF(@DocIDRef <> '' AND @DocTypeRef = 'PO' AND @TransTypeRef <> '')
1158

1159
			BEGIN
1160

1161
				DECLARE @QtyPurchaseReal DECIMAL(22,1) = 0
1162

1163
				SELECT @QtyPurchaseReal = PurchaseRealization
1164

1165
				FROM dbo.PTRPURCHREALIZATION
1166

1167
				WHERE DocNo = @DocIDRef
1168

1169
					AND MaterialID = @MaterialID 
1170

1171
					AND ItemStatus = '1'
1172

1173
				--SELECT @Quantity, @QtyPurchaseReal
1174

1175
				IF(@Quantity < @QtyPurchaseReal)
1176

1177
				BEGIN
1178

1179
					UPDATE dbo.PMDMAT0004
1180

1181
					SET Qty = @NewQty
1182

1183
						,TotalValuation = @NewTotalValuation
1184

1185
						,ChangeBy = @UserID
1186

1187
						,ChangeDate = @now16
1188

1189
					WHERE (CompanyID = @CompanyID OR @CompanyID = '')
1190

1191
						AND (MaterialID = @MaterialID)
1192

1193
						AND (LogisticAreaID = @LogisticArea OR @LogisticArea = '')
1194

1195
						AND (Warehouse = @Warehouse OR @Warehouse = '')
1196

1197
						AND (Storage = @Storage OR @Storage = '')
1198

1199
						AND (Storage = @Bin OR @Bin = '')
1200

1201
						AND (SeqID = @MinSeqMat4)
1202

1203

1204

1205
					UPDATE dbo.PMDMAT0001
1206

1207
					SET MAP = @NewMAP
1208

1209
						,ChangeBy = @UserID
1210

1211
						,ChangeDate = @now16
1212

1213
					FROM dbo.PMDMAT0001
1214

1215
					WHERE MaterialID = @MaterialID
1216

1217

1218

1219
					UPDATE dbo.PMDMAT0004
1220

1221
					SET TotalValuation = (CONVERT(DECIMAL(22,2),Qty) * @NewMAP)
1222

1223
						,ChangeBy = @UserID
1224

1225
						,ChangeDate = @now16
1226

1227
					WHERE (MaterialID = @MaterialID)
1228

1229
						AND (SeqID <> @MinSeqMat4)	
1230

1231

1232

1233
					DECLARE @MaxSeqPurReal DECIMAL(22,2) = 0
1234

1235
					SELECT @MaxSeqPurReal = MAX(DocItemID)
1236

1237
					FROM dbo.PTRPURCHREALIZATION
1238

1239
					WHERE DocNo = @DocIDRef
1240

1241
					
1242

1243
					INSERT INTO PTRPURCHREALIZATION
1244

1245
					SELECT @DocIDRef AS [DocNo]
1246

1247
						  ,@MaxSeqPurReal + 1 AS [DocItemID]
1248

1249
						  ,[ItemType]
1250

1251
						  ,[MaterialID]
1252

1253
						  ,@Quantity
1254

1255
						  ,[MaterialUnit]
1256

1257
						  ,@CompanyID
1258

1259
						  ,@LogisticArea
1260

1261
						  ,@Warehouse
1262

1263
						  ,@Storage
1264

1265
						  ,@Bin
1266

1267
						  ,'2' AS ItemStatus
1268

1269
						  ,@Quantity * @PricePurSatuan AS TotAmount
1270

1271
						  ,[StockType]
1272

1273
						  ,@UserID
1274

1275
						  ,@now16
1276

1277
						  ,@UserID
1278

1279
						  ,@now16
1280

1281
					FROM dbo.PTRPURCHREALIZATION 
1282

1283
					WHERE DocNo = @DocIDRef 
1284

1285
						AND MaterialID = @MaterialID
1286

1287
						AND ItemStatus = '1'
1288

1289

1290

1291
					UPDATE dbo.PTRPURCHREALIZATION
1292

1293
					SET PurchaseRealization = (PurchaseRealization - @Quantity)
1294

1295
						,TotAmount = (PurchaseRealization - @Quantity) * @PricePurSatuan
1296

1297
						,ChangeBy = @UserID
1298

1299
						,ChangeDate = @now16
1300

1301
					WHERE DocNo = @DocIDRef 
1302

1303
						AND MaterialID = @MaterialID
1304

1305
						AND ItemStatus = '1'
1306

1307

1308

1309
					UPDATE dbo.PTRPURCHITEM 
1310

1311
					SET ItemStatus = '1'
1312

1313
						,ChangeBy = @UserID
1314

1315
						,ChangeDate = @now16
1316

1317
					WHERE DocNo = @DocIDRef
1318

1319
						AND Material = @MaterialID
1320

1321

1322

1323
					SET @IsSuccess = 'Y'
1324

1325
				END
1326

1327
				ELSE IF(@Quantity = @QtyPurchaseReal)
1328

1329
				BEGIN
1330

1331
					UPDATE dbo.PMDMAT0004
1332

1333
					SET Qty = @NewQty
1334

1335
						,TotalValuation = @NewTotalValuation
1336

1337
						,ChangeBy = @UserID
1338

1339
						,ChangeDate = @now16
1340

1341
					WHERE (CompanyID = @CompanyID OR @CompanyID = '')
1342

1343
						AND (MaterialID = @MaterialID)
1344

1345
						AND (LogisticAreaID = @LogisticArea OR @LogisticArea = '')
1346

1347
						AND (Warehouse = @Warehouse OR @Warehouse = '')
1348

1349
						AND (Storage = @Storage OR @Storage = '')
1350

1351
						AND (Storage = @Bin OR @Bin = '')
1352

1353
						AND (SeqID = @MinSeqMat4)
1354

1355

1356

1357
					UPDATE dbo.PMDMAT0001
1358

1359
					SET MAP = @NewMAP
1360

1361
						,ChangeBy = @UserID
1362

1363
						,ChangeDate = @now16
1364

1365
					FROM dbo.PMDMAT0001
1366

1367
					WHERE MaterialID = @MaterialID
1368

1369

1370

1371
					UPDATE dbo.PMDMAT0004
1372

1373
					SET TotalValuation = (CONVERT(DECIMAL(22,2),Qty) * @NewMAP)
1374

1375
						,ChangeBy = @UserID
1376

1377
						,ChangeDate = @now16
1378

1379
					WHERE (MaterialID = @MaterialID)
1380

1381
						AND (SeqID <> @MinSeqMat4)	
1382

1383

1384

1385
					UPDATE dbo.PTRPURCHREALIZATION
1386

1387
					SET ItemStatus = '2'
1388

1389
						,Warehouse = @Warehouse
1390

1391
						,LogisticAreaID = @LogisticArea
1392

1393
						,Storage = @Storage
1394

1395
						,Bin = @Bin
1396

1397
						,ChangeBy = @UserID
1398

1399
						,ChangeDate = @now16
1400

1401
					WHERE DocNo = @DocIDRef 
1402

1403
						AND MaterialID = @MaterialID
1404

1405
						AND ItemStatus = '1'
1406

1407

1408

1409
					UPDATE dbo.PTRPURCHITEM 
1410

1411
					SET ItemStatus = '2'
1412

1413
						,ChangeBy = @UserID
1414

1415
						,ChangeDate = @now16
1416

1417
					WHERE DocNo = @DocIDRef
1418

1419
						AND Material = @MaterialID
1420

1421

1422

1423
					SET @IsSuccess = 'Y'
1424

1425
				END
1426

1427
				ELSE 
1428

1429
				BEGIN
1430

1431
					SET @IsSuccess = 'OVERQTY'
1432

1433
				END
1434

1435

1436

1437
				SELECT @CekItemNotDone = COUNT(ItemStatus)
1438

1439
				FROM dbo.PTRPURCHITEM 
1440

1441
				WHERE DocNo = @DocIDRef AND (ItemStatus = '0' OR ItemStatus = '1')
1442

1443

1444

1445
				IF(@CekItemNotDone = 0)
1446

1447
				BEGIN
1448

1449
					UPDATE dbo.PTRPURCHHEAD
1450

1451
					SET ProcessStatus = 'C'
1452

1453
					WHERE DocNo = @DocIDRef 
1454

1455
				END
1456

1457
			END
1458

1459
			IF(@DocIDRef <> ''AND @TransTypeRef = 'PRD')
1460

1461
			BEGIN
1462

1463
				UPDATE dbo.PMDMAT0004
1464

1465
				SET Qty = @NewQty
1466

1467
					,TotalValuation = @NewTotalValuation
1468

1469
					,ChangeBy = @UserID
1470

1471
					,ChangeDate = @now16
1472

1473
				WHERE (CompanyID = @CompanyID OR @CompanyID = '')
1474

1475
					AND (MaterialID = @MaterialID)
1476

1477
					AND (LogisticAreaID = @LogisticArea OR @LogisticArea = '')
1478

1479
					AND (Warehouse = @Warehouse OR @Warehouse = '')
1480

1481
					AND (Storage = @Storage OR @Storage = '')
1482

1483
					AND (Bin = @Bin OR @Bin = '')
1484

1485
					AND (SeqID = @MinSeqMat4)
1486

1487

1488

1489
				UPDATE dbo.PMDMAT0001
1490

1491
				SET MAP = @NewMAP
1492

1493
					,ChangeBy = @UserID
1494

1495
					,ChangeDate = @now16
1496

1497
				FROM dbo.PMDMAT0001
1498

1499
				WHERE MaterialID = @MaterialID
1500

1501

1502

1503
				UPDATE dbo.PMDMAT0004
1504

1505
				SET TotalValuation = (CONVERT(DECIMAL(22,2),Qty) * @NewMAP)
1506

1507
					,ChangeBy = @UserID
1508

1509
					,ChangeDate = @now16
1510

1511
				WHERE (MaterialID = @MaterialID)
1512

1513
					AND (SeqID <> @MinSeqMat4)
1514

1515

1516

1517
				UPDATE PMDMATWIP
1518

1519
				SET StockStatus = '0005'
1520

1521
					,ChangeBy = @UserID
1522

1523
					,ChangeDate = @now16
1524

1525
				--SELECT * FROM PMDMATWIP
1526

1527
				WHERE ProdID = @DocIDRef
1528

1529
					AND MaterialID = @MaterialID
1530

1531
				
1532

1533
				DECLARE @SPK VARCHAR(20)
1534

1535
				SELECT @SPK = SpkID
1536

1537
				FROM PMDMATWIP
1538

1539
				WHERE ProdID = @DocIDRef
1540

1541
					AND MaterialID = @MaterialID
1542

1543

1544

1545
				UPDATE PMDMATWIP
1546

1547
				SET DocStatus = '4'
1548

1549
					,StockStatus = '0005'
1550

1551
					,ChangeBy = @UserID
1552

1553
					,ChangeDate = @now16
1554

1555
				--SELECT * FROM PMDMATWIP
1556

1557
				WHERE ProdID = @SPK
1558

1559
					AND MaterialID = @MaterialID 
1560

1561

1562

1563
				UPDATE PTRPRODUCTIONITEM
1564

1565
				SET Status = '2'
1566

1567
					,ChangeBy = @UserID
1568

1569
					,ChangeDate = @now16
1570

1571
				--SELECT * FROM PTRPRODUCTIONITEM
1572

1573
				WHERE DocNo = @DocIDRef
1574

1575
					AND FlowType = 'RCPT'
1576

1577
				
1578

1579
				UPDATE PTRPRODUCTIONHEAD
1580

1581
				SET DocStatus = '4'
1582

1583
					,ProcessStatus = 'C'
1584

1585
					,ChangeBy = @UserID
1586

1587
					,ChangeDate = @now16
1588

1589
				--SELECT * FROM PTRPRODUCTIONHEAD
1590

1591
				WHERE DocNo = @SPK
1592

1593

1594

1595
				UPDATE PTRPRODUCTIONITEM
1596

1597
				SET Status = '2'
1598

1599
					,ChangeBy = @UserID
1600

1601
					,ChangeDate = @now16
1602

1603
				--SELECT * FROM PTRPRODUCTIONITEM
1604

1605
				WHERE DocNo = @SPK
1606

1607
					AND FlowType = 'RCPT'
1608

1609

1610

1611
				SET @IsSuccess = 'Y'
1612

1613
			END
1614

1615
			ELSE
1616

1617
			BEGIN
1618

1619
				UPDATE dbo.PMDMAT0004
1620

1621
				SET Qty = @NewQty
1622

1623
					,TotalValuation = @NewTotalValuation
1624

1625
					,ChangeBy = @UserID
1626

1627
					,ChangeDate = @now16
1628

1629
				WHERE (CompanyID = @CompanyID OR @CompanyID = '')
1630

1631
					AND (MaterialID = @MaterialID)
1632

1633
					AND (LogisticAreaID = @LogisticArea OR @LogisticArea = '')
1634

1635
					AND (Warehouse = @Warehouse OR @Warehouse = '')
1636

1637
					AND (Storage = @Storage OR @Storage = '')
1638

1639
					AND (Storage = @Bin OR @Bin = '')
1640

1641
					AND (SeqID = @MinSeqMat4)
1642

1643

1644

1645
				UPDATE dbo.PMDMAT0001
1646

1647
				SET MAP = @NewMAP
1648

1649
					,ChangeBy = @UserID
1650

1651
					,ChangeDate = @now16
1652

1653
				FROM dbo.PMDMAT0001
1654

1655
				WHERE MaterialID = @MaterialID
1656

1657

1658

1659
				UPDATE dbo.PMDMAT0004
1660

1661
				SET TotalValuation = (CONVERT(DECIMAL(22,2),Qty) * @NewMAP)
1662

1663
					,ChangeBy = @UserID
1664

1665
					,ChangeDate = @now16
1666

1667
				WHERE (MaterialID = @MaterialID)
1668

1669
					AND (SeqID <> @MinSeqMat4)
1670

1671

1672

1673
				SET @IsSuccess = 'Y'
1674

1675
			END
1676

1677
		END
1678

1679
	END
1680

1681
END
1682

1683

1684

1685
--IF(@DocType = 'MTPR')
1686

1687
--BEGIN
1688

1689
--	IF(@ItemFlow = 'ISSU')
1690

1691
--	BEGIN
1692

1693
--		IF(ISNULL(@ExistStock,0) < @Quantity)
1694

1695
--		BEGIN 
1696

1697
--			SET @IsSuccess = 'OVERQTY' 
1698

1699
--		END
1700

1701
--		ELSE
1702

1703
--		BEGIN
1704

1705
--			SET @NewStock = @ExistStock - @Quantity
1706

1707
--			SET @NewEachMAP = @ExistTotalMAP / @ExistStock  ---- menggunakan MAP sebelumnya
1708

1709
--			SET @NewTotalMAP = @NewEachMAP * @NewStock
1710

1711
--			--SELECT @NewStock, @NewEachMAP, @NewTotalMAP
1712

1713
--			IF (@IsExist > 0)
1714

1715
--			BEGIN
1716

1717
--				SET @IsSuccess = 'Y'
1718

1719
--				IF(@DocIDRef <> '' AND @DocTypeRef <> '' AND @TransTypeRef <> '')
1720

1721
--				BEGIN
1722

1723
--					DELETE FROM PMDMAT0004
1724

1725
--					--SELECT * FROM PMDMAT0004
1726

1727
--					WHERE MaterialID = @MaterialID
1728

1729
--						AND DocIDRef = @DocIDRef 
1730

1731
--						AND DocTypeRef = @DocTypeRef 
1732

1733
--						AND TransTypeRef = @TransTypeRef
1734

1735
--				END
1736

1737
--				ELSE
1738

1739
--				BEGIN
1740

1741
--					UPDATE dbo.PMDMAT0004
1742

1743
--					SET Qty = CONVERT(VARCHAR(4), ISNULL(@NewStock,0))
1744

1745
--						,TotalValuation = ISNULL(@NewTotalMAP,0)
1746

1747
--						,ChangeBy = @UserID
1748

1749
--						,ChangeDate = @now16
1750

1751
--					WHERE MaterialID = @MaterialID AND StockStatus = '0001' AND (CompanyID = @CompanyID OR @CompanyID = '')
1752

1753
--						AND (Warehouse = @Warehouse OR @Warehouse = '') AND (Storage = @Storage OR @Storage = '') AND (Bin = @Bin OR @Bin = '')
1754

1755
--						AND SeqID = @MinSeqMatExist
1756

1757
--				END
1758

1759
--			END
1760

1761
--		END
1762

1763
--	END
1764

1765
--	ELSE IF(@ItemFlow = 'RCPT')
1766

1767
--	BEGIN
1768

1769
--		SET @NewStock = @ExistStock + @Quantity
1770

1771
--		SET @NewEachMAP = @TotalPrice / @Quantity
1772

1773
--		SET @NewTotalMAP = @NewEachMAP * @NewStock
1774

1775

1776

1777
--		IF (@IsExist > 0)
1778

1779
--		BEGIN
1780

1781

1782

1783
--			SET @IsSuccess = 'Y'
1784

1785
--			UPDATE dbo.PMDMAT0004
1786

1787
--			SET Qty = @NewStock
1788

1789
--				,TotalValuation = @NewTotalMAP
1790

1791
--				,ChangeBy = @UserID
1792

1793
--				,ChangeDate = @now16
1794

1795
--			WHERE MaterialID = @MaterialID AND StockStatus = '0001' AND (CompanyID = @CompanyID OR @CompanyID = '')
1796

1797
--				AND (Warehouse = @Warehouse OR @Warehouse = '') AND (Storage = @Storage OR @Storage = '') AND (Bin = @Bin OR @Bin = '')
1798

1799
--				AND SeqID = @MinSeqMatExist
1800

1801
--		END
1802

1803
--		ELSE IF (@IsExist = 0)
1804

1805
--		BEGIN
1806

1807
--			SET @IsSuccess = 'Y'	
1808

1809
--			INSERT INTO dbo.PMDMAT0004
1810

1811
--			SELECT DISTINCT @MaterialID	
1812

1813
--							,@MaxSeqMatExist + 1
1814

1815
--							,@CompanyID
1816

1817
--							,@LogisticArea
1818

1819
--							,@Warehouse
1820

1821
--							,@Storage
1822

1823
--							,@Bin
1824

1825
--							,'0001'
1826

1827
--							,'1' AS StockType
1828

1829
--							,'122324'
1830

1831
--							,CONVERT(VARCHAR(4),@Quantity)
1832

1833
--							,CONVERT(DECIMAL(18,2),@TotalPrice)
1834

1835
--							,1
1836

1837
--							,'113124'
1838

1839
--							,@UserID AS CreateBy
1840

1841
--							,@now16 AS CreateDate
1842

1843
--							,@UserID AS ChangeBy
1844

1845
--							,@now16 AS ChangeDate
1846

1847
--							,'' AS SORDID 
1848

1849
--							,'' AS PRODID
1850

1851
--							,'' AS INTRID
1852

1853
--							,'' AS POID 
1854

1855
--							,'' AS DocIDREf
1856

1857
--							,'' AS DocTypeRef
1858

1859
--							,'' AS TransTypeRef
1860

1861
--		END
1862

1863
--	END
1864

1865
--END
1866

1867

1868

1869
SELECT @IsSuccess AS IsSuccess
1870

1871

1872

1873
DELETE FROM @TblMAT4
1874

1875

1876

1877

1878

1879

1880

1881

1882

1883

1884

1885

1886

1887

    (1-1/1)