| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300 |
- -- S1-S4 P0 UAT write (AIDOP tenant 797403760988229)
- -- Batch: S1S4_UAT_20260604_RQ_V1
- SET @tenant_id := 797403760988229;
- SET @batch_no := 'S1S4_UAT_20260604_RQ_V1';
- SET @operator_id := 1300000000111;
- SET @operator_name := 'UAT数据导入';
- SET @now := NOW();
- SET @factory_id := 797403760988229;
- SET @id_base := 9106000400000001;
- DROP TEMPORARY TABLE IF EXISTS tmp_s1_uat_so;
- CREATE TEMPORARY TABLE tmp_s1_uat_so (
- bill_no VARCHAR(64) NOT NULL PRIMARY KEY,
- target_id BIGINT NOT NULL,
- custom_no VARCHAR(64) NULL,
- custom_name VARCHAR(128) NULL,
- order_date DATETIME NULL,
- delivery_date DATETIME NULL,
- urgent INT DEFAULT 0
- );
- INSERT INTO tmp_s1_uat_so VALUES
- ('MPO482024102300001',@id_base+1,'CUST0005','WKQXGFYXGE','2024-10-23','2024-10-23',1),
- ('MPO482025010900002',@id_base+2,'CUST0005','WKQXGFYXGE','2025-01-09','2025-01-09',1),
- ('MPO482024120200003',@id_base+3,'CUST0005','WKQXGFYXGE','2024-12-02','2024-12-02',1),
- ('MPO482025012100001',@id_base+4,'CUST0005','WKQXGFYXGE','2025-01-21','2025-01-21',1),
- ('MPO482025011300004',@id_base+5,'CUST0005','WKQXGFYXGE','2025-01-13','2025-01-13',1);
- DROP TEMPORARY TABLE IF EXISTS tmp_s1_uat_so_line;
- CREATE TEMPORARY TABLE tmp_s1_uat_so_line (
- target_id BIGINT NOT NULL PRIMARY KEY,
- source_entry VARCHAR(32) NOT NULL,
- bill_no VARCHAR(64) NOT NULL,
- entry_seq INT NOT NULL,
- item_number VARCHAR(64) NULL,
- qty DECIMAL(18,4) NULL,
- plan_date DATETIME NULL
- );
- INSERT INTO tmp_s1_uat_so_line VALUES
- (@id_base+101,'604078133665861','MPO482024102300001',1,'3121C0035',1500,'2024-10-29'),
- (@id_base+102,'604078133665862','MPO482024102300001',2,'1A0C885',3500,'2024-10-29'),
- (@id_base+103,'631771616395333','MPO482025010900002',1,'3121C0035',850,'2025-01-18'),
- (@id_base+104,'631771616399429','MPO482025010900002',2,'3124C0015',850,'2025-01-21'),
- (@id_base+105,'618329124159557','MPO482024120200003',1,'1AB9275',800,'2024-12-03'),
- (@id_base+106,'636029208526917','MPO482025012100001',1,'91C0D2C',600,'2025-02-13'),
- (@id_base+107,'636029208526918','MPO482025012100001',2,'91CC0231',100,'2025-02-13'),
- (@id_base+108,'633180644831301','MPO482025011300004',1,'322AD001',5500,'2025-02-11'),
- (@id_base+109,'633180644831302','MPO482025011300004',2,'3221C0031',5500,'2025-02-18');
- DROP TEMPORARY TABLE IF EXISTS tmp_s2_uat_morder;
- CREATE TEMPORARY TABLE tmp_s2_uat_morder (
- target_mo_id BIGINT NOT NULL PRIMARY KEY,
- target_me_id BIGINT NOT NULL,
- source_entry VARCHAR(32) NOT NULL,
- bill_no VARCHAR(64) NOT NULL,
- morder_no VARCHAR(128) NOT NULL,
- product_code VARCHAR(128) NULL,
- need_number DECIMAL(23,10) NULL
- );
- INSERT INTO tmp_s2_uat_morder VALUES
- (@id_base+201,@id_base+401,'604078133665861','MPO482024102300001','M500029406','32100035',1500),
- (@id_base+202,@id_base+402,'604078133665862','MPO482024102300001','M500029407','1000885',3500),
- (@id_base+203,@id_base+403,'631771616395333','MPO482025010900002','M500067189','32100035',850),
- (@id_base+204,@id_base+404,'631771616399429','MPO482025010900002','M500067190','32400015',850),
- (@id_base+205,@id_base+405,'618329124159557','MPO482024120200003','M500053856','1009275',800),
- (@id_base+206,@id_base+406,'636029208526917','MPO482025012100001','M500077552','93000230',600),
- (@id_base+207,@id_base+407,'636029208526918','MPO482025012100001','M500077553','93000231',100),
- (@id_base+208,@id_base+408,'633180644831301','MPO482025011300004','M500070779','32100001',5500),
- (@id_base+209,@id_base+409,'633180644831302','MPO482025011300004','M500070780','32100031',5500);
- DROP TEMPORARY TABLE IF EXISTS tmp_s3_uat_pr;
- CREATE TEMPORARY TABLE tmp_s3_uat_pr (
- voucher BIGINT NOT NULL PRIMARY KEY,
- pr_billno VARCHAR(64) NOT NULL,
- morder_no VARCHAR(128) NOT NULL,
- bill_no VARCHAR(64) NOT NULL,
- icitem_code VARCHAR(64) NULL,
- pr_rqty DECIMAL(18,4) NULL,
- mo_id BIGINT NOT NULL
- );
- INSERT INTO tmp_s3_uat_pr VALUES
- (@id_base+501,'PR-UAT-20260604-01','M500029406','MPO482024102300001','32100035',1500,@id_base+201),
- (@id_base+502,'PR-UAT-20260604-02','M500029407','MPO482024102300001','1000885',3500,@id_base+202),
- (@id_base+503,'PR-UAT-20260604-03','M500067189','MPO482025010900002','32100035',850,@id_base+203),
- (@id_base+504,'PR-UAT-20260604-04','M500067190','MPO482025010900002','32400015',850,@id_base+204),
- (@id_base+505,'PR-UAT-20260604-05','M500053856','MPO482024120200003','1009275',800,@id_base+205),
- (@id_base+506,'PR-UAT-20260604-06','M500077552','MPO482025012100001','93000230',600,@id_base+206),
- (@id_base+507,'PR-UAT-20260604-07','M500077553','MPO482025012100001','93000231',100,@id_base+207),
- (@id_base+508,'PR-UAT-20260604-08','M500070779','MPO482025011300004','32100001',5500,@id_base+208),
- (@id_base+509,'PR-UAT-20260604-09','M500070780','MPO482025011300004','32100031',5500,@id_base+209);
- DROP TEMPORARY TABLE IF EXISTS tmp_s3_uat_po_line;
- CREATE TEMPORARY TABLE tmp_s3_uat_po_line (
- pur_ord VARCHAR(48) NOT NULL,
- line_no INT NOT NULL,
- sales_ord VARCHAR(64) NOT NULL,
- work_ord VARCHAR(128) NULL,
- item_num VARCHAR(60) NOT NULL,
- qty DECIMAL(15,5) NOT NULL,
- PRIMARY KEY (pur_ord, line_no)
- );
- INSERT INTO tmp_s3_uat_po_line VALUES
- ('PO-UAT-20260604-01',1,'MPO482024102300001','M500029406','3121C0035',1500),
- ('PO-UAT-20260604-01',2,'MPO482024102300001','M500029407','1A0C885',3500),
- ('PO-UAT-20260604-02',1,'MPO482025010900002','M500067189','3121C0035',850),
- ('PO-UAT-20260604-02',2,'MPO482025010900002','M500067190','3124C0015',850),
- ('PO-UAT-20260604-03',1,'MPO482024120200003','M500053856','1AB9275',800),
- ('PO-UAT-20260604-03',2,'MPO482024120200003','M500053856','RAW-SUB-01',200),
- ('PO-UAT-20260604-04',1,'MPO482025012100001','M500077552','91C0D2C',600),
- ('PO-UAT-20260604-04',2,'MPO482025012100001','M500077553','91CC0231',100),
- ('PO-UAT-20260604-05',1,'MPO482025011300004','M500070779','322AD001',5500),
- ('PO-UAT-20260604-05',2,'MPO482025011300004','M500070780','3221C0031',5500);
- DROP TEMPORARY TABLE IF EXISTS tmp_s3_uat_po_hdr;
- CREATE TEMPORARY TABLE tmp_s3_uat_po_hdr (
- pur_ord VARCHAR(48) NOT NULL PRIMARY KEY,
- sales_ord VARCHAR(64) NOT NULL,
- work_ord VARCHAR(128) NULL
- );
- INSERT INTO tmp_s3_uat_po_hdr
- SELECT pur_ord, MIN(sales_ord), MIN(work_ord) FROM tmp_s3_uat_po_line GROUP BY pur_ord;
- DROP TEMPORARY TABLE IF EXISTS tmp_s4_uat_ship;
- CREATE TEMPORARY TABLE tmp_s4_uat_ship (
- ship_id BIGINT NOT NULL PRIMARY KEY,
- po_billno VARCHAR(48) NOT NULL,
- shddh VARCHAR(64) NOT NULL
- );
- INSERT INTO tmp_s4_uat_ship VALUES
- (@id_base+601,'PO-UAT-20260604-01','SH-UAT-20260604-01'),
- (@id_base+602,'PO-UAT-20260604-02','SH-UAT-20260604-02'),
- (@id_base+603,'PO-UAT-20260604-03','SH-UAT-20260604-03');
- START TRANSACTION;
- INSERT INTO crm_seorder (
- Id, bill_no, order_type, custom_no, custom_name,
- date, rdate, urgent, bill_from, closed, IsDeleted,
- create_by_name, create_time, update_by_name, update_time,
- tenant_id, factory_id
- )
- SELECT target_id, bill_no, 1, custom_no, custom_name,
- order_date, delivery_date, urgent,
- CONCAT('UAT导入:', @batch_no), 0, 0,
- @operator_name, @now, @operator_name, @now,
- @tenant_id, @factory_id
- FROM tmp_s1_uat_so;
- INSERT INTO crm_seorderentry (
- Id, seorder_id, bill_no, entry_seq, item_number,
- qty, plan_date, date, IsDeleted,
- create_by_name, create_time, update_by_name, update_time,
- tenant_id, factory_id, seorderentry_id
- )
- SELECT l.target_id, s.target_id, l.bill_no, l.entry_seq, l.item_number,
- l.qty, l.plan_date, s.order_date, 0,
- @operator_name, @now, @operator_name, @now,
- @tenant_id, @factory_id, l.target_id
- FROM tmp_s1_uat_so_line l
- JOIN tmp_s1_uat_so s ON s.bill_no = l.bill_no;
- INSERT INTO mes_morder (
- Id, morder_no, morder_date, morder_state, product_code, product_name,
- need_number, morder_production_number, IsDeleted,
- create_by_name, create_time, update_by_name, update_time,
- tenant_id, factory_id
- )
- SELECT target_mo_id, morder_no, @now, 'Released', product_code, product_code,
- need_number, need_number, 0,
- @operator_name, @now, @operator_name, @now,
- @tenant_id, @factory_id
- FROM tmp_s2_uat_morder;
- INSERT INTO mes_moentry (
- Id, moentry_moid, moentry_mono, soentry_id, fbill_no,
- need_number, morder_production_number, IsDeleted,
- create_by_name, create_time, tenant_id, factory_id
- )
- SELECT m.target_me_id, m.target_mo_id, m.morder_no, l.target_id, m.bill_no,
- m.need_number, m.need_number, 0,
- @operator_name, @now, @tenant_id, @factory_id
- FROM tmp_s2_uat_morder m
- JOIN tmp_s1_uat_so_line l ON l.source_entry = m.source_entry;
- INSERT INTO WorkOrdMaster (
- Domain, WorkOrd, ItemNum, Status, QtyOrded, QtyCompleted, LbrVar,
- OrdDate, DueDate, SalesJob, BusinessID, IsActive, IsConfirm, Priority, Urgent,
- tenant_id, CreateTime, UpdateTime
- )
- SELECT '8010', morder_no, product_code, 'R',
- need_number, 0, 0, @now, DATE_ADD(@now, INTERVAL 14 DAY), bill_no,
- 0, 1, 1, 0, 0, @tenant_id, @now, @now
- FROM tmp_s2_uat_morder;
- INSERT INTO srm_pr_main (
- Id, pr_billno, pr_purchaseid, pr_purchasenumber, pr_purchasename,
- pr_rqty, pr_aqty, pr_sqty, icitem_id, icitem_name,
- state, pr_type, currencytype,
- create_by, create_by_name, create_time, update_by, update_by_name, update_time,
- tenant_id, factory_id, IsDeleted, IsRequireGoods
- )
- SELECT p.voucher, p.pr_billno, p.mo_id, p.morder_no, p.morder_no,
- p.pr_rqty, 0, 0, 0, p.icitem_code,
- 1, 1, 0,
- @operator_id, @operator_name, @now, @operator_id, @operator_name, @now,
- @tenant_id, @factory_id, 0, 0
- FROM tmp_s3_uat_pr p;
- INSERT INTO PurOrdMaster (
- OwnerApplication, APAcct, CostCtr, APSubAcct, Bank, BillTo, BlanketOrd, Buyer, CloseDate,
- CommentIndex, Confirming, Consignment, Contact, Contract, CreditTermsInt, CreditTerms, Curr,
- CycleCode, DeliverTo, Disc, Domain, DueDate, DutyType, BlanketStart, BlanketEnd, ExchRate,
- ERSOption, EstVal, Sequence, ExchRate1, ExchRate2, RateType, FixedPrice, FixedRate, FOB, Frt,
- FSMType, FSTID, InvoicesVia, EMTPO, Language, MaxAgingDays, PurOrd, OrdDate, PartialOK,
- AmtPrepaid, LastPriceDt, PricingDate, PrintPO, Project, DiscTbl, PriceTbl, ERSPriceListOption,
- PST, PSTID, Recurr, `Release`, Rel, ReqBy, Revision, Remark, Scheduled, SchedulesVia,
- ServiceCharge, ShipTo, ShipVia, Site, SecondarySOCrHold, PrimarySO, SpecialCharge, Status,
- Taxable, TaxClass, TaxDate, TaxEnvironment, Tax1, Tax2, Tax3, TaxUsage, TermsofTrade,
- TransportDays, Typed, Ufld1, Ufld2, EnteredBy, Supp, Transm, BusinessID, CreateUser,
- UpdateUser, CreateTime, UpdateTime, EffTime, IsActive, IsConfirm, Potype, Department,
- IsChanged, TaxIn, Amt, `Usage`, CustAddress, CustContact, CustPhone, SalesOrd, CustPO,
- IsPriceChanged, CustName, Rev, RoleNo, InvoiceType, PricingMethod, ERPfld1, ERPWorkOrd,
- WorkOrd, tenant_id
- )
- SELECT
- m.OwnerApplication, m.APAcct, m.CostCtr, m.APSubAcct, m.Bank, m.BillTo, m.BlanketOrd, @operator_name, m.CloseDate,
- m.CommentIndex, m.Confirming, m.Consignment, m.Contact, m.Contract, m.CreditTermsInt, m.CreditTerms, m.Curr,
- m.CycleCode, m.DeliverTo, m.Disc, m.Domain, m.DueDate, m.DutyType, m.BlanketStart, m.BlanketEnd, m.ExchRate,
- m.ERSOption, m.EstVal, m.Sequence, m.ExchRate1, m.ExchRate2, m.RateType, m.FixedPrice, m.FixedRate, m.FOB, m.Frt,
- m.FSMType, m.FSTID, m.InvoicesVia, m.EMTPO, m.Language, m.MaxAgingDays, h.pur_ord, @now, m.PartialOK,
- m.AmtPrepaid, m.LastPriceDt, m.PricingDate, m.PrintPO, m.Project, m.DiscTbl, m.PriceTbl, m.ERSPriceListOption,
- m.PST, m.PSTID, m.Recurr, m.`Release`, m.Rel, m.ReqBy, m.Revision, CONCAT('UAT:', @batch_no), m.Scheduled, m.SchedulesVia,
- m.ServiceCharge, m.ShipTo, m.ShipVia, m.Site, m.SecondarySOCrHold, m.PrimarySO, m.SpecialCharge, m.Status,
- m.Taxable, m.TaxClass, m.TaxDate, m.TaxEnvironment, m.Tax1, m.Tax2, m.Tax3, m.TaxUsage, m.TermsofTrade,
- m.TransportDays, m.Typed, m.Ufld1, m.Ufld2, m.EnteredBy, 'VEN00060', m.Transm, m.BusinessID, @operator_name,
- @operator_name, @now, @now, m.EffTime, m.IsActive, m.IsConfirm, 'PT', m.Department,
- m.IsChanged, m.TaxIn, m.Amt, m.`Usage`, m.CustAddress, m.CustContact, m.CustPhone, h.sales_ord, m.CustPO,
- m.IsPriceChanged, m.CustName, m.Rev, m.RoleNo, m.InvoiceType, m.PricingMethod, m.ERPfld1, m.ERPWorkOrd,
- h.work_ord, @tenant_id
- FROM tmp_s3_uat_po_hdr h
- CROSS JOIN (SELECT * FROM PurOrdMaster WHERE PurOrd='PW202605100002' AND tenant_id=@tenant_id LIMIT 1) m;
- INSERT INTO PurOrdDetail (
- QtyBO, RctCost, CreditTermsInt, UpdateCurrentCost, CumReceived1, CumReceived2, CumReceived3, CumReceived4,
- Disc, FixedPrice, InspectReq, SingleLot, SupplyPer, PurOrd, PST, PackingSlipQty, PayUMConv, PurCost,
- RctQty, QtyOrded, QtyReceived, QtyReturned, Active, QtyReleased, RctUMConversion, Scheduled, ScheduledChanged,
- SchedMRPReq, SafetyDays, SafetyHours, StdCost, Taxable, TaxIn, MaxTaxableAmt, TransportHours, UMConversion, VAT,
- IsActive, IsConfirm, Potype, IsChanged, TaxRate, IsRounding, ReceiptQty, BarCodeQty, IsClosed, QtyReturnedRefund, CumQtyBO,
- Line, ItemNum, UM, DueDate, LotSerial, PurOrdRecID, Status, WorkOrd,
- CreateUser, CreateTime, UpdateUser, UpdateTime, tenant_id
- )
- SELECT
- 0,0,0,0,0,0,0,0,0,0,0,0,0,pl.pur_ord,0,0,1,0,0,pl.qty,0,0,1,0,1,0,0,0,0,0,0,1,1,0,0,1,0,
- 1,1,'PT',0,0,0,0,0,0,0,0,
- pl.line_no, pl.item_num, 'EA', DATE_ADD(@now, INTERVAL 14 DAY), '', 0, 'O', pl.work_ord,
- @operator_name, @now, @operator_name, @now, @tenant_id
- FROM tmp_s3_uat_po_line pl;
- SET @ds_seq := 800;
- INSERT INTO srm_polist_ds (
- Id, domain, icdsid, dsnum, status, itemnum, um, purgroup,
- suppliercode, supplier, ponumber, poline, schedqty, needdate, remarks, tenant_id
- )
- SELECT
- @id_base+(@ds_seq:=@ds_seq+1),
- '8010', @id_base+800, CONCAT('DS-', pl.pur_ord, '-', pl.line_no),
- 'P', pl.item_num, 'EA', 'PG01', 'VEN00060', 'VEN00060',
- pl.pur_ord, pl.line_no, pl.qty, DATE_ADD(@now, INTERVAL 14 DAY), '', @tenant_id
- FROM tmp_s3_uat_po_line pl
- CROSS JOIN (SELECT @ds_seq:=800) init;
- INSERT INTO scm_shd (id, po_billno, shddh, sh_purchase_num, estimated_delivery_date, tjrxm, tjrq, state)
- SELECT ship_id, po_billno, shddh, 'VEN00060', DATE_ADD(@now, INTERVAL 7 DAY), @operator_name, DATE_FORMAT(@now,'%Y-%m-%d'), 0
- FROM tmp_s4_uat_ship;
- SET @zb_seq := 700;
- INSERT INTO scm_shdzb (id, glid, sh_material_code, sh_delivery_quantity, po_bill, po_billline)
- SELECT @id_base+(@zb_seq:=@zb_seq+1), CAST(s.ship_id AS CHAR), pl.item_num, pl.qty, pl.pur_ord, CAST(pl.line_no AS CHAR)
- FROM tmp_s3_uat_po_line pl
- JOIN tmp_s4_uat_ship s ON s.po_billno = pl.pur_ord
- CROSS JOIN (SELECT @zb_seq:=700) init;
- COMMIT;
- SELECT 'crm_seorder' AS tbl, COUNT(*) cnt FROM crm_seorder WHERE tenant_id=@tenant_id AND bill_from LIKE CONCAT('UAT导入:',@batch_no,'%');
- SELECT 'crm_seorderentry' AS tbl, COUNT(*) cnt FROM crm_seorderentry WHERE tenant_id=@tenant_id AND bill_no IN (SELECT bill_no FROM tmp_s1_uat_so);
- SELECT 'mes_morder' AS tbl, COUNT(*) cnt FROM mes_morder WHERE tenant_id=@tenant_id AND morder_no LIKE 'M5000%';
- SELECT 'srm_pr_main' AS tbl, COUNT(*) cnt FROM srm_pr_main WHERE tenant_id=@tenant_id AND pr_billno LIKE 'PR-UAT-20260604-%';
- SELECT 'PurOrdMaster' AS tbl, COUNT(*) cnt FROM PurOrdMaster WHERE tenant_id=@tenant_id AND Remark LIKE CONCAT('%',@batch_no,'%');
- SELECT 'scm_shd' AS tbl, COUNT(*) cnt FROM scm_shd WHERE shddh LIKE 'SH-UAT-20260604-%';
- SELECT so.bill_no, COUNT(DISTINCT se.Id) line_cnt, COUNT(DISTINCT mo.Id) morder_cnt, COUNT(DISTINCT pom.PurOrd) po_cnt
- FROM crm_seorder so
- LEFT JOIN crm_seorderentry se ON se.seorder_id=so.Id AND se.tenant_id=@tenant_id
- LEFT JOIN mes_moentry me ON me.soentry_id=se.Id AND me.tenant_id=@tenant_id
- LEFT JOIN mes_morder mo ON mo.Id=me.moentry_moid AND mo.tenant_id=@tenant_id
- LEFT JOIN PurOrdMaster pom ON pom.SalesOrd=so.bill_no AND pom.tenant_id=@tenant_id
- LEFT JOIN PurOrdDetail pd ON pd.PurOrd=pom.PurOrd AND pd.tenant_id=@tenant_id
- WHERE so.tenant_id=@tenant_id AND so.bill_from LIKE CONCAT('UAT导入:',@batch_no,'%')
- GROUP BY so.bill_no;
|