From 20943f263c31beec3f25fcbeb09c73350248e74b Mon Sep 17 00:00:00 2001
From: Junjie <fallin.jie@qq.com>
Date: 星期一, 20 十一月 2023 16:37:05 +0800
Subject: [PATCH] # 1、图号从ERP获取 2、商品档案增加规格和图号搜索

---
 src/main/java/com/zy/asrs/task/kingdee/handler/InboundOrderHandler.java |  250 +++++++++++++++++++++++++------------------------
 1 files changed, 127 insertions(+), 123 deletions(-)

diff --git a/src/main/java/com/zy/asrs/task/kingdee/handler/InboundOrderHandler.java b/src/main/java/com/zy/asrs/task/kingdee/handler/InboundOrderHandler.java
index ca000fd..945997c 100644
--- a/src/main/java/com/zy/asrs/task/kingdee/handler/InboundOrderHandler.java
+++ b/src/main/java/com/zy/asrs/task/kingdee/handler/InboundOrderHandler.java
@@ -127,7 +127,7 @@
                 //鐗╂枡鐘舵�� FUseOrgId .FNumber
                 FDocumentStatus="C";
                 jsonObject.put("FilterString", "FCreateDate>'"+sdf.format(time)+"' and FDocumentStatus='"+FDocumentStatus+"' and FUseOrgId .FNumber='201'");
-                jsonObject.put("FieldKeys", "FName,FNumber,FCreateDate,FSpecification,FDocumentStatus");
+                jsonObject.put("FieldKeys", "FName,FNumber,FCreateDate,FSpecification,FDocumentStatus,FTuhao");
                 // FName : 鐗╂枡鍚嶇О 锛�
                 // FNumber 锛氱墿鏂欑紪鍙凤紱
                 // FCreateDate 锛氱墿鏂欏垱寤烘椂闂达紱
@@ -138,7 +138,7 @@
                 DocType docType= docTypeService.selectById(docName);
                 //鍗曟嵁鐘舵��
                 FDocumentStatus="B";
-                jsonObject.put("FilterString", "FCreateDate>'"+sdf.format(docType.getCreateTime())+"' and FDocumentStatus='"+FDocumentStatus+"'");
+                jsonObject.put("FilterString", "FCreateDate>'"+sdf.format(docType.getCreateTime())+"' and FStockId.Fname='绔嬪簱'"+" and FDocumentStatus='"+FDocumentStatus+"'");
                 jsonObject.put("FieldKeys", "FBillNo,FCreateDate,FMaterialId.FNumber,FMaterialId.FName,FMaterialId.FSpecification,"+anfme+",FDocumentStatus");
                 // FBillNo :鍗曟嵁缂栧彿锛�
                 // FCreateDate 锛氬崟鎹垱寤烘椂闂达紱
@@ -167,131 +167,135 @@
                         .build()
                         .doPost();
                 JSONArray data = JSON.parseArray(response);
-                if(data.size()>0){
-                    success = true;
-                }
-                if(i==0){
-                    for (int j = 0; j < data.size(); j++) {
-                        JSONArray jsonArray = data.getJSONArray(j);
-                        //鐢熸垚鍟嗗搧妗f
-                        //鍟嗗搧缂栧彿
-                        Mat mat = matService.selectByMatnr(jsonArray.get(1).toString());
-                        if (mat == null) {
-                            mat = new Mat();
-                            Tag tag=new Tag();
-                            mat.setMatnr(jsonArray.get(1).toString());
-                            mat.setMaktx(jsonArray.get(0).toString());
-                            mat.setSpecs(jsonArray.get(3).toString());//瑙勬牸
-                            mat.setTagId(20L);
-                            //瀵圭編鍥芥椂闂磋繘琛岃浆鎹�
-                            DateTimeFormatter dateFormat = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss.SSS");
-                            DateTimeFormatter formatter = DateTimeFormatter.ISO_LOCAL_DATE_TIME;
-                            LocalDateTime dateTime = LocalDateTime.parse(jsonArray.get(2).toString(), formatter);
-                            String format = dateFormat.format(dateTime);
-                            Date date = sdf.parse(format);
-                            mat.setCreateTime(date);//鍟嗗搧鍒涘缓鏃堕棿
-                            mat.setUpdateTime(new Date());
-                            mat.setStatus(1);
-                            //鏈�鏂版姄鍙栧晢鍝佹椂闂�
-                            tag.setCreateTime(date);
-                        tagService.update(tag,new EntityWrapper<Tag>().eq("id",20));
-                        if (!matService.insert(mat)) {
-                            throw new CoolException("鏈嶅姟鍣ㄥ唴閮ㄩ敊璇紝璇疯仈绯荤鐞嗗憳");
+                if(data.size()>0) {
+                if (data.getJSONArray(0).get(0).toString().length()<20) {
+                        if (i == 0) {
+                            for (int j = 0; j < data.size(); j++) {
+                                JSONArray jsonArray = data.getJSONArray(j);
+                                //鐢熸垚鍟嗗搧妗f
+                                //鍟嗗搧缂栧彿
+                                Mat mat = matService.selectByMatnr(jsonArray.get(1).toString());
+                                if (mat == null) {
+                                    mat = new Mat();
+                                    Tag tag = new Tag();
+                                    mat.setMatnr(jsonArray.get(1).toString());
+                                    mat.setMaktx(jsonArray.get(0).toString());
+                                    mat.setSpecs(jsonArray.get(3).toString());//瑙勬牸
+                                    mat.setModel(jsonArray.get(5).toString());//鍥惧彿
+                                    mat.setTagId(20L);
+                                    //瀵圭編鍥芥椂闂磋繘琛岃浆鎹�
+                                    DateTimeFormatter dateFormat = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss.SSS");
+                                    DateTimeFormatter formatter = DateTimeFormatter.ISO_LOCAL_DATE_TIME;
+                                    LocalDateTime dateTime = LocalDateTime.parse(jsonArray.get(2).toString(), formatter);
+                                    String format = dateFormat.format(dateTime);
+                                    Date date = sdf.parse(format);
+                                    mat.setCreateTime(date);//鍟嗗搧鍒涘缓鏃堕棿
+                                    mat.setUpdateTime(new Date());
+                                    mat.setStatus(1);
+                                    //鏈�鏂版姄鍙栧晢鍝佹椂闂�
+                                    tag.setCreateTime(date);
+                                    tagService.update(tag, new EntityWrapper<Tag>().eq("id", 20));
+                                    if (!matService.insert(mat)) {
+                                        throw new CoolException("鏈嶅姟鍣ㄥ唴閮ㄩ敊璇紝璇疯仈绯荤鐞嗗憳");
+                                    } else {
+                                        log.info("鍚屾鏂扮墿鏂橻鍟嗗搧缂栧彿锛歿}]", mat.getMatnr());
+                                    }
+                                }
+                            }
                         } else {
-                            log.info("鍚屾鏂扮墿鏂橻鍟嗗搧缂栧彿锛歿}]", mat.getMatnr());
+                            for (int j = 0; j < data.size(); j++) {
+                                JSONArray jsonArray = data.getJSONArray(j);
+                                Order order = orderService.selectByNo(jsonArray.get(0).toString());
+                                if (Cools.isEmpty(order)) {
+                                    DocType docType = docTypeService.selectById(docName);
+                                    Date now = new Date();
+                                    // 鍗曟嵁涓绘。
+                                    order = new Order(
+                                            String.valueOf(snowflakeIdWorker.nextId()),    // 缂栧彿[闈炵┖]
+                                            jsonArray.get(0).toString(),    // 璁㈠崟缂栧彿
+                                            DateUtils.convert(now),    // 鍗曟嵁鏃ユ湡
+                                            docType.getDocId(),    // 鍗曟嵁绫诲瀷
+                                            null,    // 椤圭洰缂栧彿
+                                            null,    //
+                                            null,    // 璋冩嫧椤圭洰缂栧彿
+                                            null,    // 鍒濆绁ㄦ嵁鍙�
+                                            null,    // 绁ㄦ嵁鍙�
+                                            null,    // 瀹㈡埛缂栧彿
+                                            null,    // 瀹㈡埛
+                                            null,    // 鑱旂郴鏂瑰紡
+                                            null,    // 鎿嶄綔浜哄憳
+                                            null,    // 鍚堣閲戦
+                                            null,    // 浼樻儬鐜�
+                                            null,    // 浼樻儬閲戦
+                                            null,    // 閿�鍞垨閲囪喘璐圭敤鍚堣
+                                            null,    // 瀹炰粯閲戦
+                                            null,    // 浠樻绫诲瀷
+                                            null,    // 涓氬姟鍛�
+                                            null,    // 缁撶畻澶╂暟
+                                            null,    // 閭垂鏀粯绫诲瀷
+                                            null,    // 閭垂
+                                            null,    // 浠樻鏃堕棿
+                                            null,    // 鍙戣揣鏃堕棿
+                                            null,    // 鐗╂祦鍚嶇О
+                                            null,    // 鐗╂祦鍗曞彿
+                                            1L,    // 璁㈠崟鐘舵��
+                                            1,    // 鐘舵��
+                                            9527L,    // 娣诲姞浜哄憳
+                                            now,    // 娣诲姞鏃堕棿
+                                            9527L,    // 淇敼浜哄憳
+                                            now,    // 淇敼鏃堕棿
+                                            null    // 澶囨敞
+                                    );
+                                    //瀵圭編鍥芥椂闂磋繘琛岃浆鎹�
+                                    DateTimeFormatter dateFormat = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss.SSS");
+                                    DateTimeFormatter formatter = DateTimeFormatter.ISO_LOCAL_DATE_TIME;
+                                    LocalDateTime dateTime = LocalDateTime.parse(jsonArray.get(1).toString(), formatter);
+                                    String format = dateFormat.format(dateTime);
+                                    Date date = sdf.parse(format);
+                                    //鏈�鏂版姄鍙栨椂闂�
+                                    docType.setCreateTime(date);
+                                    docTypeService.update(docType, new EntityWrapper<DocType>().eq("doc_id", docName));
+                                    if (!orderService.insert(order)) {
+                                        throw new CoolException("鐢熸垚鍗曟嵁涓绘。澶辫触锛岃鑱旂郴绠$悊鍛�");
+                                    }
+                                }
+                                //鐗╂枡缂栫爜
+                                Mat mat = matService.selectByMatnr(jsonArray.get(2).toString());
+                                if (Cools.isEmpty(mat)) {
+                                    throw new CoolException(jsonArray.get(2).toString() + "缂栧彿鍟嗗搧妫�绱㈠け璐ワ紝璇峰厛娣诲姞鍟嗗搧");
+                                }
+                                OrderDetl orderDetl1 = orderDetlService.selectOne(new EntityWrapper<OrderDetl>().eq("order_no", jsonArray.get(0).toString()).eq("matnr", jsonArray.get(2).toString()));
+                                if (!Cools.isEmpty(orderDetl1)) {
+                                    continue;
+                                }
+                                DocType docType = docTypeService.selectById(docName);
+                                OrderDetl orderDetl = new OrderDetl();
+                                orderDetl.sync(mat);
+                                orderDetl.setBatch(null);
+                                orderDetl.setAnfme(Double.parseDouble(jsonArray.get(5).toString()));
+                                orderDetl.setOrderId(order.getId());
+                                orderDetl.setOrderNo(order.getOrderNo());
+                                orderDetl.setCreateBy(9527L);
+                                orderDetl.setCreateTime(new Date());
+                                orderDetl.setUpdateBy(9527L);
+                                orderDetl.setUpdateTime(new Date());
+                                orderDetl.setStatus(1);
+                                orderDetl.setQty(0.0D);
+                                DateTimeFormatter dateFormat = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss.SSS");
+                                DateTimeFormatter formatter = DateTimeFormatter.ISO_LOCAL_DATE_TIME;
+                                LocalDateTime dateTime = LocalDateTime.parse(jsonArray.get(1).toString(), formatter);
+                                String format = dateFormat.format(dateTime);
+                                Date date = sdf.parse(format);
+                                //鏈�鏂版姄鍙栨椂闂�
+                                docType.setCreateTime(date);
+                                if (!orderDetlService.insert(orderDetl)) {
+                                    throw new CoolException("鐢熸垚鍗曟嵁鏄庣粏澶辫触锛岃鑱旂郴绠$悊鍛�");
+                                }
+                            }
                         }
-                        }
+                    }else {
                     }
                 }else {
-                    for(int j=0;j<data.size();j++){
-                        JSONArray jsonArray = data.getJSONArray(j);
-                         Order order = orderService.selectByNo(jsonArray.get(0).toString());
-                        if (Cools.isEmpty(order)) {
-                        DocType docType = docTypeService.selectById(docName);
-                        Date now = new Date();
-                        // 鍗曟嵁涓绘。
-                        order = new Order(
-                                String.valueOf(snowflakeIdWorker.nextId()),    // 缂栧彿[闈炵┖]
-                                jsonArray.get(0).toString(),    // 璁㈠崟缂栧彿
-                                DateUtils.convert(now),    // 鍗曟嵁鏃ユ湡
-                                docType.getDocId(),    // 鍗曟嵁绫诲瀷
-                                null,    // 椤圭洰缂栧彿
-                                null,    //
-                                null,    // 璋冩嫧椤圭洰缂栧彿
-                                null,    // 鍒濆绁ㄦ嵁鍙�
-                                null,    // 绁ㄦ嵁鍙�
-                                null,    // 瀹㈡埛缂栧彿
-                                null,    // 瀹㈡埛
-                                null,    // 鑱旂郴鏂瑰紡
-                                null,    // 鎿嶄綔浜哄憳
-                                null,    // 鍚堣閲戦
-                                null,    // 浼樻儬鐜�
-                                null,    // 浼樻儬閲戦
-                                null,    // 閿�鍞垨閲囪喘璐圭敤鍚堣
-                                null,    // 瀹炰粯閲戦
-                                null,    // 浠樻绫诲瀷
-                                null,    // 涓氬姟鍛�
-                                null,    // 缁撶畻澶╂暟
-                                null,    // 閭垂鏀粯绫诲瀷
-                                null,    // 閭垂
-                                null,    // 浠樻鏃堕棿
-                                null,    // 鍙戣揣鏃堕棿
-                                null,    // 鐗╂祦鍚嶇О
-                                null,    // 鐗╂祦鍗曞彿
-                                1L,    // 璁㈠崟鐘舵��
-                                1,    // 鐘舵��
-                                9527L,    // 娣诲姞浜哄憳
-                                now,    // 娣诲姞鏃堕棿
-                                9527L,    // 淇敼浜哄憳
-                                now,    // 淇敼鏃堕棿
-                                null    // 澶囨敞
-                        );
-                        //瀵圭編鍥芥椂闂磋繘琛岃浆鎹�
-                        DateTimeFormatter dateFormat = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss.SSS");
-                        DateTimeFormatter formatter = DateTimeFormatter.ISO_LOCAL_DATE_TIME;
-                        LocalDateTime dateTime = LocalDateTime.parse(jsonArray.get(1).toString(), formatter);
-                        String format = dateFormat.format(dateTime);
-                        Date date = sdf.parse(format);
-                        //鏈�鏂版姄鍙栨椂闂�
-                        docType.setCreateTime(date);
-                        docTypeService.update(docType,new EntityWrapper<DocType>().eq("doc_id",docName));
-                        if (!orderService.insert(order)) {
-                            throw new CoolException("鐢熸垚鍗曟嵁涓绘。澶辫触锛岃鑱旂郴绠$悊鍛�");
-                        }
-                        }
-                        //鐗╂枡缂栫爜
-                        Mat mat = matService.selectByMatnr(jsonArray.get(2).toString());
-                        if (Cools.isEmpty(mat)) {
-                            throw new CoolException(jsonArray.get(2).toString() + "缂栧彿鍟嗗搧妫�绱㈠け璐ワ紝璇峰厛娣诲姞鍟嗗搧");
-                        }
-                        OrderDetl orderDetl1=orderDetlService.selectOne(new EntityWrapper<OrderDetl>().eq("order_no",jsonArray.get(0).toString()).eq("matnr",jsonArray.get(2).toString()));
-                        if(!Cools.isEmpty(orderDetl1)){
-                            continue;
-                        }
-                        DocType docType = docTypeService.selectById(docName);
-                        OrderDetl orderDetl = new OrderDetl();
-                        orderDetl.sync(mat);
-                        orderDetl.setBatch(null);
-                        orderDetl.setAnfme(Double.parseDouble(jsonArray.get(5).toString()));
-                        orderDetl.setOrderId(order.getId());
-                        orderDetl.setOrderNo(order.getOrderNo());
-                        orderDetl.setCreateBy(9527L);
-                        orderDetl.setCreateTime(new Date());
-                        orderDetl.setUpdateBy(9527L);
-                        orderDetl.setUpdateTime(new Date());
-                        orderDetl.setStatus(1);
-                        orderDetl.setQty(0.0D);
-                        DateTimeFormatter dateFormat = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss.SSS");
-                        DateTimeFormatter formatter = DateTimeFormatter.ISO_LOCAL_DATE_TIME;
-                        LocalDateTime dateTime = LocalDateTime.parse(jsonArray.get(1).toString(), formatter);
-                        String format = dateFormat.format(dateTime);
-                        Date date = sdf.parse(format);
-                        //鏈�鏂版姄鍙栨椂闂�
-                        docType.setCreateTime(date);
-                        if (!orderDetlService.insert(orderDetl)) {
-                            throw new CoolException("鐢熸垚鍗曟嵁鏄庣粏澶辫触锛岃鑱旂郴绠$悊鍛�");
-                        }
-                    }
                 }
             } catch (Exception e) {
                 log.error("fail", e);

--
Gitblit v1.9.1