Merge remote-tracking branch 'origin/master'

master
wws 1 year ago
commit 551b3e8b7e

@ -1,5 +1,5 @@
#for test only!
#Mon Nov 06 18:11:07 CST 2023
#Wed Dec 13 13:57:23 CST 2023
jco.destination.pool_capacity=true
jco.client.lang=zh
jco.client.ashost=192.168.0.54
@ -8,4 +8,4 @@ jco.client.user=MES
jco.client.sysnr=0
jco.destination.peak_limit=20
jco.client.passwd=123456
jco.client.client=800
jco.client.client=600

@ -0,0 +1,118 @@
**** Error file opened at 20231205 092106 China Standard Time Rel 3.0.8 (2011-11-28) [721.619]
Error: >Tue Dec 05 09:21:06,526< RfcException: [null]
message: Connect to SAP gateway failed
Connection parameters: TYPE=A DEST=ABAP_AS_WITH_POOL ASHOST=192.168.230.50 SYSNR=00 PCS=1
LOCATION CPIC (TCP/IP) on local host with Unicode
ERROR partner '192.168.230.50:3300' not reached
TIME Tue Dec 05 09:21:06 2023
RELEASE 721
COMPONENT NI (network interface)
VERSION 40
RC -10
MODULE nixxi.cpp
LINE 3283
DETAIL NiPConnect2: 192.168.230.50:3300
SYSTEM CALL connect
ERRNO 10060
ERRNO TEXT WSAETIMEDOUT: Connection timed out
COUNTER 2
Return code: RFC_FAILURE(1)
error group: 102
key: RFC_ERROR_COMMUNICATION
Error: >Tue Dec 05 09:23:26,607< RfcException: [null]
message: Connect to SAP gateway failed
Connection parameters: TYPE=A DEST=ABAP_AS_WITH_POOL ASHOST=192.168.230.50 SYSNR=00 PCS=1
LOCATION CPIC (TCP/IP) on local host with Unicode
ERROR partner '192.168.230.50:3300' not reached
TIME Tue Dec 05 09:23:26 2023
RELEASE 721
COMPONENT NI (network interface)
VERSION 40
RC -10
MODULE nixxi.cpp
LINE 3283
DETAIL NiPConnect2: 192.168.230.50:3300
SYSTEM CALL connect
ERRNO 10060
ERRNO TEXT WSAETIMEDOUT: Connection timed out
COUNTER 2
Return code: RFC_FAILURE(1)
error group: 102
key: RFC_ERROR_COMMUNICATION
**** Error file opened at 20231205 100000 China Standard Time Rel 3.0.8 (2011-11-28) [721.619]
Error: >Tue Dec 05 10:00:00,058< >RfcGetException rc (7) message: 数值范围对象 ZMESPROID 不存在
<RfcGetException
Error: >Tue Dec 05 10:01:14,955< >RfcGetException rc (7) message: 数值范围对象 ZMESPROID 不存在
<RfcGetException
**** Error file opened at 20231208 164650 China Standard Time Rel 3.0.8 (2011-11-28) [721.619]
Error: >Fri Dec 08 16:46:50,007< >RfcGetException rc (7) message: ##.#####,####
<RfcGetException
Error: >Fri Dec 08 16:49:21,354< >RfcGetException rc (7) message: ##.#####,####
<RfcGetException
**** Error file opened at 20231208 165102 China Standard Time Rel 3.0.8 (2011-11-28) [721.619]
Error: >Fri Dec 08 16:51:02,041< >RfcGetException rc (7) message: ##.#####,####
<RfcGetException
**** Error file opened at 20231211 151721 China Standard Time Rel 3.0.8 (2011-11-28) [721.619]
Error: >Mon Dec 11 15:17:21,694< >RfcGetException rc (7) message: ##.#####,####
<RfcGetException
**** Error file opened at 20231211 160016 China Standard Time Rel 3.0.8 (2011-11-28) [721.619]
Error: [1] >Mon Dec 11 16:00:16,825< RfcException: [DEV|erpdev]
message: connection closed without message (CM_NO_DATA_RECEIVED)
Return code: RFC_CLOSED(6)
error group: 102
key: RFC_ERROR_COMMUNICATION
Exception raised by DEV|erpdev
**** Error file opened at 20231211 172940 China Standard Time Rel 3.0.8 (2011-11-28) [721.619]
Error: >Mon Dec 11 17:29:40,539< >RfcGetException rc (7) message: Syntax error in program SAPLZMES .
<RfcGetException
Error: >Mon Dec 11 17:30:08,292< >RfcGetException rc (7) message: Syntax error in program SAPLZMES .
<RfcGetException
Error: >Mon Dec 11 17:30:54,764< >RfcGetException rc (7) message: Syntax error in program SAPLZMES .
<RfcGetException
**** Error file opened at 20231211 173328 China Standard Time Rel 3.0.8 (2011-11-28) [721.619]
Error: >Mon Dec 11 17:33:28,521< >RfcGetException rc (7) message: Syntax error in program SAPLZMES .
<RfcGetException
Error: >Mon Dec 11 17:35:37,983< >RfcGetException rc (7) message: Syntax error in program SAPLZMES .
<RfcGetException
**** Error file opened at 20231211 173748 China Standard Time Rel 3.0.8 (2011-11-28) [721.619]
Error: >Mon Dec 11 17:37:48,395< >RfcGetException rc (7) message: Syntax error in program SAPLZMES .
<RfcGetException
**** Error file opened at 20231211 182025 China Standard Time Rel 3.0.8 (2011-11-28) [721.619]
Error: >Mon Dec 11 18:20:25,371< >RfcGetException rc (7) message: Syntax error in program SAPLZMES .
<RfcGetException
Error: >Mon Dec 11 18:20:41,130< >RfcGetException rc (7) message: Syntax error in program SAPLZMES .
<RfcGetException
Error: >Mon Dec 11 18:21:52,709< >RfcGetException rc (7) message: Syntax error in program SAPLZMES .
<RfcGetException

@ -66,4 +66,16 @@ public interface RemoteSapService {
@PostMapping("/sap/bomSync")
public R sapBomSync();
/**
*
*/
@PostMapping("/sap/sapBackflushMP")
public R sapBackflushMP(List<SapBackflushMPQuery> sapBackflushMPQueryList);
/**订单物料领料过账、原材料补料、订单物料退料过账接口MB1A**/
public R sapMaterialPosting(@RequestBody List<SapMaterialPosting> sapMaterialPostingList);
/**智慧工厂储位信息*/
@PostMapping("/sap/sapLgortInfo")
public R sapLgortInfo(@RequestBody(required = false) Map<String, Object> map);
}

@ -20,4 +20,12 @@ public class SapCloseOrderQuery {
public void setOrder(String order) {
this.order = order;
}
@Override
public String toString() {
return "SapCloseOrderQuery{" +
"leadOrder='" + leadOrder + '\'' +
", order='" + order + '\'' +
'}';
}
}

@ -5,16 +5,17 @@ package com.op.system.api.domain.sap;
*/
public class SapCreateOrder {
//计划工厂
private String werks;
//订单类型
private String aufpar;
//物料编号
private String matnr;
//数量
private String quantity;
//开始时间
private String dates;
//完成时间
private String datee;
@ -66,6 +67,8 @@ public class SapCreateOrder {
this.datee = datee;
}
// @NotNull(message = "计划工厂不能为空")
// @NotBlank(message = "计划工厂不能为空")
// @Size(min = 0, max = 4, message = "计划工厂长度不能超过4个字符")

@ -1,16 +1,20 @@
package com.op.sap.domain.vo;
package com.op.system.api.domain.sap;
//智慧工厂-订单物料领料过账、原材料补料、订单物料退料过账MB1A
/**
* AUFNR
* BWART
* PLANT
* LGORT
* MATNR
* QUANTITY
* MEINS
* BATCH
AUFNR CHAR 12 0
BWART CHAR 3 0
PLANT CHAR 4 0
GL_ACCOUNT CHAR 10 0
COSTCENTER CHAR 10 0
GR_RCPT CHAR 12 0 /
LGORT CHAR 4 0
MATNR CHAR 18 0
QUANTITY QUAN 13 3
MEINS UNIT 3 0
BATCH CHAR 10 0
*/
public class SapMaterialPosting {
@ -24,12 +28,39 @@ public class SapMaterialPosting {
private String aufnr;
private String bwart;
private String plant;
private String gl_account;
private String costcenter;
private String gr_rcpt;
private String lgort;
private String matnr;
private String quantity;
private String meins;
private String batch;
public String getGl_account() {
return gl_account;
}
public void setGl_account(String gl_account) {
this.gl_account = gl_account;
}
public String getCostcenter() {
return costcenter;
}
public void setCostcenter(String costcenter) {
this.costcenter = costcenter;
}
public String getGr_rcpt() {
return gr_rcpt;
}
public void setGr_rcpt(String gr_rcpt) {
this.gr_rcpt = gr_rcpt;
}
public String getAufnr() {
return aufnr;
}

@ -52,4 +52,15 @@ public class SapRouterQuery {
public void setAedat(String aedat) {
this.aedat = aedat;
}
@Override
public String toString() {
return "SapRouterQuery{" +
"matnr='" + matnr + '\'' +
", werks='" + werks + '\'' +
", arbpl='" + arbpl + '\'' +
", andat='" + andat + '\'' +
", aedat='" + aedat + '\'' +
'}';
}
}

@ -58,6 +58,6 @@ public class SapShopOrderQuery {
return "{aufnr:"+":"+getAufnr()+","+
"matnr"+":"+getMatnr()+","+
"erdat"+":"+getErdat()+","+
"erdat"+":"+getWerk()+"}";
"werk"+":"+getWerk()+"}";
}
}

@ -79,6 +79,20 @@ public class RemoteSapFallbackFactory implements FallbackFactory<RemoteSapServic
return R.fail("sap shopUpdateSync失败" + throwable.getMessage());
}
@Override
public R sapBackflushMP(List<SapBackflushMPQuery> sapBackflushMPQueryList) {
return R.fail("反冲物料领料过账失败" + throwable.getMessage());
}
@Override
public R sapMaterialPosting(List<SapMaterialPosting> sapMaterialPostingList) {
return R.fail("订单物料领料过账、原材料补料、订单物料退料过账接口MB1A失败" + throwable.getMessage());
}
@Override
public R sapLgortInfo(Map<String, Object> map) {
return R.fail("储位仓库信息获取失败" + throwable.getMessage());
}
};
}

@ -86,48 +86,44 @@ public class EquSpareApplyServiceImpl implements IEquSpareApplyService {
@Override
@DS("#header.poolName")
public AjaxResult insertEquSpareApply(EquSpareApply equSpareApply) {
try {
//equSpareApply.getSpareApplyLists().size() 是在维修申领备件的时候进行的操作 批量新增
if(equSpareApply.getSpareApplyLists().size() >= 1){
List<EquSpareApply> list = equSpareApply.getSpareApplyLists();
for(EquSpareApply applyList:list){
applyList.setApplyId(IdUtils.fastSimpleUUID());
//生成领料单code //申领单号
String serialNum = String.format("%03d", equSpareApplyMapper.selectSerialNumber());
String code = DateUtils.dateTimeNow(DateUtils.YYYYMMDD) + applyList.getWorkCode().substring(2);
//申领单号
equSpareApply.setApplyCode("AW" + code + serialNum);
//领用时间
applyList.setApplyTime(DateUtils.getNowDate());
//申领人
applyList.setApplyPeople(SecurityUtils.getUsername());
//工厂号
HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest();
String key = "#header.poolName";
applyList.setFactoryCode(request.getHeader(key.substring(8)).replace("ds_",""));
//创建人、创建时间
applyList.setCreateTime(DateUtils.getNowDate());
applyList.setCreateBy(SecurityUtils.getUsername());
equSpareApplyMapper.insertEquSpareApply(applyList);
//更新完备品申领单后,更新库存
SparePartsLedger sparePartsLedger = new SparePartsLedger();
sparePartsLedger.setStorageId(applyList.getStorageId());
BigDecimal applyNum = applyList.getSpareQuantity();
BigDecimal amount = applyList.getAmount();
sparePartsLedger.setAmount(amount.subtract(applyNum));
sparePartsLedgerMapper.updateSparePartsLedger(sparePartsLedger);
if(equSpareApply.getSpareApplyLists() != null){
List<EquSpareApply> list = equSpareApply.getSpareApplyLists();
for(EquSpareApply applyList:list){
applyList.setApplyId(IdUtils.fastSimpleUUID());
String serialNum = String.format("%03d", equSpareApplyMapper.selectSerialNumber());
if(applyList.getWorkCode() != null){
String code = applyList.getWorkCode();
applyList.setApplyCode("AW" + code.substring(2) + serialNum);
}
}else{
//领用时间
applyList.setApplyTime(DateUtils.getNowDate());
//申领人
applyList.setApplyPeople(SecurityUtils.getUsername());
//工厂号
HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest();
String key = "#header.poolName";
applyList.setFactoryCode(request.getHeader(key.substring(8)).replace("ds_",""));
//创建人、创建时间
applyList.setCreateTime(DateUtils.getNowDate());
applyList.setCreateBy(SecurityUtils.getUsername());
equSpareApplyMapper.insertEquSpareApply(applyList);
//更新完备品申领单后,更新库存
SparePartsLedger sparePartsLedger = new SparePartsLedger();
sparePartsLedger.setStorageId(applyList.getStorageId());
BigDecimal applyNum = applyList.getSpareQuantity();
BigDecimal amount = applyList.getAmount();
sparePartsLedger.setAmount(amount.subtract(applyNum));
sparePartsLedgerMapper.updateSparePartsLedger(sparePartsLedger);
}
}else if(equSpareApply.getSpareApplyLists() == null){
equSpareApply.setApplyId(IdUtils.fastSimpleUUID());
String serialNum = String.format("%03d", equSpareApplyMapper.selectSerialNumber());
if(equSpareApply.getWorkCode().length() == 12){
//生成领料单code 十五位单号
equSpareApply.setApplyCode("A" + equSpareApply.getWorkCode() + serialNum);
}else if(equSpareApply.getWorkCode().length() > 12){
equSpareApply.setApplyCode("AW" + equSpareApply.getWorkCode().substring(2) + serialNum);
}else{
if(equSpareApply.getWorkCode() != null){
String code = equSpareApply.getWorkCode();
equSpareApply.setApplyCode("AW" + code.substring(2) + serialNum);
} else{
//普通申领单
equSpareApply.setApplyCode("AN" + DateUtils.dateTimeNow(DateUtils.YYYYMMDD) + equSpareApply.getSpareUseEquipment() + serialNum);
equSpareApply.setApplyCode("AW" + DateUtils.dateTimeNow(DateUtils.YYYYMMDD) + equSpareApply.getSpareUseEquipment() + serialNum);
}
//领用时间
equSpareApply.setApplyTime(DateUtils.getNowDate());
@ -151,9 +147,6 @@ public class EquSpareApplyServiceImpl implements IEquSpareApplyService {
sparePartsLedgerMapper.updateSparePartsLedger(sparePartsLedger);
}
return success("新增申领记录成功!");
} catch (Exception e) {
return error();
}
}
/**

@ -67,8 +67,8 @@ public interface MesPrepareDetailMapper {
/**
* idlist
* @param prepareId
* @param workorderCode
* @return
*/
List<MesPrepareDetail> selectPrintPrepareDetailList(String prepareId);
List<MesPrepareDetail> selectPrintPrepareDetailList(String workorderCode);
}

@ -16,7 +16,7 @@ import com.op.mes.service.IMesPrepareDetailService;
/**
* mesService
*
*
* @author Open Platform
* @date 2023-08-04
*/
@ -29,7 +29,7 @@ public class MesPrepareDetailServiceImpl implements IMesPrepareDetailService {
/**
* mes
*
*
* @param recordId mes
* @return mes
*/
@ -40,7 +40,7 @@ public class MesPrepareDetailServiceImpl implements IMesPrepareDetailService {
/**
* mes
*
*
* @param mesPrepareDetail mes
* @return mes
*/
@ -51,7 +51,7 @@ public class MesPrepareDetailServiceImpl implements IMesPrepareDetailService {
/**
* mes
*
*
* @param mesPrepareDetail mes
* @return
*/
@ -63,7 +63,7 @@ public class MesPrepareDetailServiceImpl implements IMesPrepareDetailService {
/**
* mes
*
*
* @param mesPrepareDetail mes
* @return
*/
@ -75,7 +75,7 @@ public class MesPrepareDetailServiceImpl implements IMesPrepareDetailService {
/**
* mes
*
*
* @param recordIds mes
* @return
*/
@ -86,7 +86,7 @@ public class MesPrepareDetailServiceImpl implements IMesPrepareDetailService {
/**
* mes
*
*
* @param recordId mes
* @return
*/
@ -103,7 +103,7 @@ public class MesPrepareDetailServiceImpl implements IMesPrepareDetailService {
@DS("#header.poolName")
public AjaxResult printPrepareByCode(String workorderCode) {
MesPrepare mesPrepare = mesPrepareMapper.selectMesPrepareByCode(workorderCode);
List<MesPrepareDetail> mesPrepareDetailList = mesPrepareDetailMapper.selectPrintPrepareDetailList(mesPrepare.getPrepareId());
List<MesPrepareDetail> mesPrepareDetailList = mesPrepareDetailMapper.selectPrintPrepareDetailList(workorderCode);
PrintPrepareVo printPrepareVo = new PrintPrepareVo();
printPrepareVo.setMesPrepare(mesPrepare);
printPrepareVo.setMesPrepareDetailList(mesPrepareDetailList);

@ -8,7 +8,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<result property="recordId" column="record_id" />
<result property="prepareId" column="prepare_id" />
<result property="materialCode" column="material_code" />
<result property="materailName" column="materail_name" />
<result property="materialName" column="material_name" />
<result property="materailSpc" column="material_spc" />
<result property="unit" column="unit" />
<result property="quantity" column="quantity" />
@ -63,12 +63,22 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
where record_id = #{recordId}
</select>
<select id="selectPrintPrepareDetailList" parameterType="String" resultMap="MesPrepareDetailResult">
select record_id, prepare_id, material_code,material_name, unit,
quantity, status, remark, attr1, attr2, attr3, attr4,
create_by, create_time, update_by, update_time, prod_type, factory_code,fund_quanlity
from mes_prepare_detail
where prepare_id = #{prepareId}
<select id="selectPrintPrepareDetailList" parameterType="String" resultType="com.op.mes.domain.MesPrepareDetail">
select
mp.workorder_name workorderCode,
mpd.material_code materialCode,
mpd.material_name materialName,
mpd.quantity,
mpd.unit,
mpd.status,
mpd.fund_quanlity fundQuanlity,
mpd.factory_code factoryCode,
ow.product_date productDate
from pro_order_workorder ow
left join mes_prepare mp on ow.workorder_code = mp.workorder_code
left join mes_prepare_detail mpd on mp.prepare_id = mpd.prepare_id
where ow.belong_work_order = #{workorderCode}
order by mp.workorder_name desc
</select>
<insert id="insertMesPrepareDetail" parameterType="MesPrepareDetail">

@ -39,63 +39,34 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
</resultMap>
<sql id="selectMesPrepareVo">
select prepare_id, workorder_code, workorder_name, parent_order, order_id, order_code, product_id, product_code, prod_type, product_name, product_spc, wet_detail_plan_id, product_date, shift_id, ancestors, status, remark, attr1, attr2, attr3, attr4, create_by, create_time, update_by, update_time, factory_code, material_code, material_name, material_spc, unit, quantity from mes_prepare
select prepare_id, workorder_code, workorder_name, parent_order, order_id, order_code, product_id,
product_code, prod_type, product_name, product_spc, wet_detail_plan_id, product_date,
shift_id, ancestors, status, remark, attr1, attr2, attr3, attr4, create_by, create_time,
update_by, update_time, factory_code, material_code, material_name, material_spc, unit, quantity
from mes_prepare
</sql>
<select id="selectMesPrepareList" parameterType="MesPrepare" resultMap="MesPrepareResult">
<select id="selectMesPrepareList" parameterType="com.op.mes.domain.MesPrepare" resultType="com.op.mes.domain.MesPrepare">
select
ms.prepare_id,
ms.workorder_code,
ms.workorder_name,
ms.parent_order,
ms.order_id,
ms.order_code,
ms.product_id,
ms.product_code,
ms.prod_type,
ms.product_name,
ms.product_spc,
ms.wet_detail_plan_id,
ms.product_date,
ms.shift_id,
ms.ancestors,
ms.status,
ms.remark,
ms.attr1,
ms.attr2,
ms.attr3,
ms.attr4,
ms.create_by,
ms.create_time,
ms.update_by,
ms.update_time,
ms.factory_code,
msd.prepare_id id,
msd.material_code,
msd.material_name,
msd.material_spc,
msd.unit,
msd.quantity
from mes_prepare ms,mes_prepare_detail msd
ms.workorder_name workorderCodeSap,
ow.workorder_code workorderCode,
ow.product_code productCode,
ow.product_name productName,
ow.product_date productDate,
ow.quantity_split quantity,
ow.unit
from mes_prepare ms
left join pro_order_workorder ow on ms.workorder_code = ow.workorder_code
<where>
<if test="workorderCode != null and workorderCode != ''"> and workorder_code like concat('%', #{workorderCode}, '%')</if>
<if test="workorderName != null and workorderName != ''"> and workorder_name like concat('%', #{workorderName}, '%')</if>
<if test="parentOrder != null and parentOrder != ''"> and parent_order = #{parentOrder}</if>
<if test="orderId != null and orderId != ''"> and order_id like concat('%', #{orderId}, '%')</if>
<if test="orderCode != null and orderCode != ''"> and order_code = #{orderCode}</if>
<if test="productId != null and productId != ''"> and product_id = #{productId}</if>
<if test="productCode != null and productCode != ''"> and product_code like concat('%', #{productCode}, '%')</if>
<if test="prodType != null and prodType != ''"> and prod_type = #{prodType}</if>
<if test="productName != null and productName != ''"> and product_name like concat('%', #{productName}, '%')</if>
<if test="productSpc != null and productSpc != ''"> and product_spc = #{productSpc}</if>
<if test="wetDetailPlanId != null and wetDetailPlanId != ''"> and wet_detail_plan_id = #{wetDetailPlanId}</if>
<if test="productDate != null "> and product_date = #{productDate}</if>
<if test="shiftId != null and shiftId != ''"> and shift_id = #{shiftId}</if>
<if test="ancestors != null and ancestors != ''"> and ancestors = #{ancestors}</if>
<if test="status != null and status != ''"> and ms.status = #{status}</if>
<if test="factoryCode != null and factoryCode != ''"> and factory_code = #{factoryCode}</if>
ow.del_flag = '0' and ow.parent_order = '0'
<if test="workorderCode != null and workorderCode != ''"> and ow.workorder_code like concat('%', #{workorderCode}, '%')</if>
<if test="workorderCodeSap != null and workorderCodeSap != ''"> and ms.workorder_name like concat('%', #{workorderCodeSap}, '%')</if>
<if test="productCode != null and productCode != ''"> and ow.product_code like concat('%', #{productCode}, '%')</if>
<if test="productName != null and productName != ''"> and ow.product_name like concat('%', #{productName}, '%')</if>
<if test="productDate != null "> and ow.product_date = #{productDate}</if>
and ms.del_flag = '0'
</where>
order by ow.product_date desc
</select>
<select id="selectMesPrepareByPrepareId" parameterType="String" resultMap="MesPrepareResult">

@ -13,15 +13,15 @@ spring:
cloud:
nacos:
discovery:
namespace: lanju-op
group: zxl
namespace: lanju-op-test
group: test
# 服务注册地址
server-addr: 175.27.215.92:8848
server-addr: 192.168.202.20:8848
config:
namespace: lanju-op
group: zxl
namespace: lanju-op-test
group: test
# 服务注册地址
server-addr: 175.27.215.92:8848
server-addr: 192.168.202.20:8848
# 配置文件格式
file-extension: yml
# 共享配置

@ -5,9 +5,7 @@ import com.op.quality.domain.QcCheckType;
import com.op.quality.domain.QcInterface;
import com.op.quality.service.IQcInterfaceService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.bind.annotation.*;
import java.util.List;
@ -37,8 +35,8 @@ public class QcInterfaceController {
* @param qcInterface
* @return
*/
@GetMapping("/getOverallInfo")
public List<QcInterface> getOverallInfo(QcInterface qcInterface) {
@PostMapping("/getOverallInfo")
public List<QcInterface> getOverallInfo(@RequestBody QcInterface qcInterface) {
return qcInterfaceService.getOverallInfo(qcInterface);
}
@ -47,8 +45,45 @@ public class QcInterfaceController {
* @param qcInterface
* @return
*/
@GetMapping("/getCheckProjectsPie")
public List<QcInterface> getCheckProjectsPie(QcInterface qcInterface) {
@PostMapping("/getCheckProjectsPie")
public List<QcInterface> getCheckProjectsPie(@RequestBody QcInterface qcInterface) {
return qcInterfaceService.getCheckProjectsPie(qcInterface);
}
/**
* --
* @param qcInterface
* @return
*/
@PostMapping("/getSupplierBadTOP5")
public List<QcInterface> getSupplierBadTOP5(@RequestBody QcInterface qcInterface) {
return qcInterfaceService.getSupplierBadTOP5(qcInterface);
}
@PostMapping("/getSupplierNoOkList")
public List<QcInterface> getSupplierNoOkList(@RequestBody QcInterface qcInterface) {
return qcInterfaceService.getSupplierNoOkList(qcInterface);
}
/**
* --
* @param qcInterface
* @return
*/
@PostMapping("/getSupplierTaskList")
public List<QcInterface> getSupplierTaskList(@RequestBody QcInterface qcInterface) {
return qcInterfaceService.getSupplierTaskList(qcInterface);
}
/**
* -
* @param qcInterface
* @return
*/
@PostMapping("/getProduceStaticInfo")
public List<QcInterface> getProduceStaticInfo(@RequestBody QcInterface qcInterface) {
return qcInterfaceService.getProduceStaticInfo(qcInterface);
}
}

@ -1,5 +1,6 @@
package com.op.quality.domain;
import com.fasterxml.jackson.annotation.JsonFormat;
import com.op.common.core.annotation.Excel;
import com.op.common.core.web.domain.BaseEntity;
import org.apache.commons.lang3.builder.ToStringBuilder;
@ -20,6 +21,106 @@ public class QcInterface extends BaseEntity {
private String quality;
private String ymd;
private String projectName;
private String checkNo;
private String incomeBatchNo;
private String orderNo;
private String materialName;
private String unit;
private String supplierName;
@JsonFormat(pattern = "yyyy-MM-dd")
private String incomeTime;
private String checkStatus;
private String checkResult;
private String checkManName;
private String checkName;
public String getCheckNo() {
return checkNo;
}
public void setCheckNo(String checkNo) {
this.checkNo = checkNo;
}
public String getIncomeBatchNo() {
return incomeBatchNo;
}
public void setIncomeBatchNo(String incomeBatchNo) {
this.incomeBatchNo = incomeBatchNo;
}
public String getOrderNo() {
return orderNo;
}
public void setOrderNo(String orderNo) {
this.orderNo = orderNo;
}
public String getMaterialName() {
return materialName;
}
public void setMaterialName(String materialName) {
this.materialName = materialName;
}
public String getUnit() {
return unit;
}
public void setUnit(String unit) {
this.unit = unit;
}
public String getSupplierName() {
return supplierName;
}
public void setSupplierName(String supplierName) {
this.supplierName = supplierName;
}
public String getIncomeTime() {
return incomeTime;
}
public void setIncomeTime(String incomeTime) {
this.incomeTime = incomeTime;
}
public String getCheckStatus() {
return checkStatus;
}
public void setCheckStatus(String checkStatus) {
this.checkStatus = checkStatus;
}
public String getCheckResult() {
return checkResult;
}
public void setCheckResult(String checkResult) {
this.checkResult = checkResult;
}
public String getCheckManName() {
return checkManName;
}
public void setCheckManName(String checkManName) {
this.checkManName = checkManName;
}
public String getCheckName() {
return checkName;
}
public void setCheckName(String checkName) {
this.checkName = checkName;
}
public String getProjectName() {
return projectName;

@ -21,4 +21,10 @@ public interface QcInterfaceMapper {
List<QcInterface> getOverallInfo(QcInterface qcInterface);
List<QcInterface> getCheckProjectsPie(QcInterface qcInterface);
List<QcInterface> getSupplierBadTOP5(QcInterface qcInterface);
List<QcInterface> getSupplierTaskList(QcInterface qcInterface);
List<QcInterface> getSupplierNoOkList(QcInterface qcInterface);
}

@ -18,4 +18,12 @@ public interface IQcInterfaceService {
List<QcInterface> getOverallInfo(QcInterface qcInterface);
List<QcInterface> getCheckProjectsPie(QcInterface qcInterface);
List<QcInterface> getSupplierBadTOP5(QcInterface qcInterface);
List<QcInterface> getSupplierTaskList(QcInterface qcInterface);
List<QcInterface> getSupplierNoOkList(QcInterface qcInterface);
List<QcInterface> getProduceStaticInfo(QcInterface qcInterface);
}

@ -13,6 +13,8 @@ import org.springframework.util.CollectionUtils;
import java.math.BigDecimal;
import java.math.RoundingMode;
import java.time.LocalDate;
import java.util.Calendar;
import java.util.List;
/**
@ -63,7 +65,63 @@ public class QcInterfaceServiceImpl implements IQcInterfaceService {
String nowYMD = DateUtils.getDate();
qcInterface.setYmd(nowYMD);
List<QcInterface> dtos = qcInterfaceMapper.getCheckProjectsPie(qcInterface);
return dtos;
}
@Override
public List<QcInterface> getSupplierBadTOP5(QcInterface qcInterface) {
DynamicDataSourceContextHolder.push(qcInterface.getFactoryCode());
String nowYMD = DateUtils.getDate();
qcInterface.setYmd(nowYMD);
List<QcInterface> dtos = qcInterfaceMapper.getSupplierBadTOP5(qcInterface);
return dtos;
}
@Override
public List<QcInterface> getSupplierTaskList(QcInterface qcInterface) {
DynamicDataSourceContextHolder.push(qcInterface.getFactoryCode());
String nowYMD = DateUtils.getDate();
qcInterface.setYmd(nowYMD);
List<QcInterface> dtos = qcInterfaceMapper.getSupplierTaskList(qcInterface);
for(QcInterface dto:dtos){
String[] ymdArray = dto.getIncomeTime().split("-");
LocalDate date1 = LocalDate.of(Integer.parseInt(ymdArray[0]),
Integer.parseInt(ymdArray[1]),
Integer.parseInt(ymdArray[2]));
LocalDate date2 = LocalDate.now();
if(date1.compareTo(date2)<0){
dto.setCheckStatus("逾期未检");
}else {
dto.setCheckStatus("0".equals(dto.getCheckStatus()) ? "待检测" : "检测完成");
}
dto.setCheckResult("Y".equals(dto.getCheckResult())?"合格":"不合格");
}
return dtos;
}
@Override
public List<QcInterface> getSupplierNoOkList(QcInterface qcInterface) {
DynamicDataSourceContextHolder.push(qcInterface.getFactoryCode());
String nowYMD = DateUtils.getDate();
qcInterface.setYmd(nowYMD);
List<QcInterface> dtos = qcInterfaceMapper.getSupplierNoOkList(qcInterface);
for(QcInterface dto:dtos){
dto.setCheckStatus("0".equals(dto.getCheckStatus())?"待检测":"检测完成");
dto.setCheckResult("Y".equals(dto.getCheckResult())?"合格":"不合格");
}
return dtos;
}
@Override
public List<QcInterface> getProduceStaticInfo(QcInterface qcInterface) {
DynamicDataSourceContextHolder.push(qcInterface.getFactoryCode());
String nowYMD = DateUtils.getDate();
qcInterface.setYmd(nowYMD);
List<QcInterface> dtos = qcInterfaceMapper.getSupplierNoOkList(qcInterface);
return dtos;
}
}

@ -191,6 +191,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<if test="factoryCode != null and factoryCode != ''">factory_code,</if>
<if test="delFlag != null">del_flag,</if>
<if test="checkType != null">check_type,</if>
<if test="typeCode != null">type_code,</if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="recordId != null">#{recordId},</if>
@ -223,6 +224,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<if test="factoryCode != null and factoryCode != ''">#{factoryCode},</if>
<if test="delFlag != null">#{delFlag},</if>
<if test="checkType != null">#{checkType},</if>
<if test="typeCode != null">#{typeCode},</if>
</trim>
</insert>

@ -145,6 +145,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<if test="factoryCode != null and factoryCode != ''">factory_code,</if>
<if test="delFlag != null">del_flag,</if>
<if test="checkType != null">check_type,</if>
<if test="typeCode != null">type_code,</if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="recordId != null">#{recordId},</if>
@ -181,6 +182,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<if test="factoryCode != null and factoryCode != ''">#{factoryCode},</if>
<if test="delFlag != null">#{delFlag},</if>
<if test="checkType != null">#{checkType},</if>
<if test="typeCode != null">#{typeCode},</if>
</trim>
</insert>

@ -128,6 +128,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<if test="factoryCode != null and factoryCode != ''">factory_code,</if>
<if test="delFlag != null">del_flag,</if>
<if test="checkType != null">check_type,</if>
<if test="typeCode != null">type_code,</if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="recordId != null">#{recordId},</if>
@ -159,6 +160,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<if test="factoryCode != null and factoryCode != ''">#{factoryCode},</if>
<if test="delFlag != null">#{delFlag},</if>
<if test="checkType != null">#{checkType},</if>
<if test="typeCode != null">#{typeCode},</if>
</trim>
</insert>

@ -101,7 +101,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
from wms_raw_order_in wroi
left join base_supplier bs on bs.supplier_code = wroi.supply_code
where wroi.active_flag = '1' and wroi.quality_status = '0'
<if test="orderNo != null">and wroi.order_no like contact like ('%',#{orderNo})</if>
<if test="orderNo != null">and wroi.order_no like concat like ('%',#{orderNo})</if>
</select>
<select id="getWorkOrder" resultType="com.op.quality.domain.QcCheckTaskIncome">
select
@ -114,7 +114,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
product_date incomeTime
from pro_order_workorder
where status != 'w5' and parent_order != '0' and workorder_code_sap is not null
<if test="orderNo != null">and workorder_code_sap like contact like ('%',#{orderNo})</if>
<if test="orderNo != null">and workorder_code_sap like concat like ('%',#{orderNo})</if>
order by product_date desc
</select>

@ -57,4 +57,101 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
</if>
group by qctd.project_no,qctd.rule_name
</select>
<select id="getSupplierBadTOP5" resultType="com.op.quality.domain.QcInterface">
select top 5 * from(
select
concat(t1.supplier_name,'-',t1.material_name) supplierName,
ROUND(t2.noOkNum*100.00/t1.allNum, 2) quality
from (
select count(0) allNum,
qct.supplier_code,qct.supplier_name,qct.material_code,qct.material_name
from qc_check_task qct
where qct.type_code = #{typeCode}
<if test='ymdType=="yyyy"'>
and CONVERT(varchar(4),qct.income_time, 120) = SUBSTRING(#{ymd},0,5)
</if>
<if test='ymdType=="mm"'>
and CONVERT(varchar(7),qct.income_time, 120) = SUBSTRING(#{ymd},0,8)
</if>
<if test='ymdType=="dd"'>
and CONVERT(varchar(10),qct.income_time, 120) = SUBSTRING(#{ymd},0,11)
</if>
group by
qct.supplier_code,qct.supplier_name,qct.material_code,qct.material_name
) t1
left join (
select
count(0) noOkNum,qct.supplier_code,qct.supplier_name,qct.material_code,qct.material_name
from qc_check_task qct
where qct.type_code = #{typeCode} and qct.check_result = 'N'
<if test='ymdType=="yyyy"'>
and CONVERT(varchar(4),qct.income_time, 120) = SUBSTRING(#{ymd},0,5)
</if>
<if test='ymdType=="mm"'>
and CONVERT(varchar(7),qct.income_time, 120) = SUBSTRING(#{ymd},0,8)
</if>
<if test='ymdType=="dd"'>
and CONVERT(varchar(10),qct.income_time, 120) = SUBSTRING(#{ymd},0,11)
</if>
group by
qct.supplier_code,qct.supplier_name,qct.material_code,qct.material_name
) t2 on t1.supplier_code = t2.supplier_code and t1.material_code = t2.material_code
) t order by t.quality desc
</select>
<select id="getSupplierTaskList" resultType="com.op.quality.domain.QcInterface">
select
qct.check_no checkNo,
qct.income_batch_no incomeBatchNo,
qct.order_no orderNo,
qct.material_name materialName,
qct.quality,
qct.unit,
qct.supplier_name supplierName,
qct.income_time incomeTime,
qct.check_status checkStatus,
qct.check_result checkResult,
qct.check_man_name checkManName,
qc.check_name checkName
from qc_check_task qct
left join qc_check_type qc on qct.check_type = qc.order_code
where qct.del_flag = '0' and qct.status = '1'
and qct.type_code = #{typeCode}
<if test='ymdType=="yyyy"'>
and CONVERT(varchar(4),qct.income_time, 120) = SUBSTRING(#{ymd},0,5)
</if>
<if test='ymdType=="mm"'>
and CONVERT(varchar(7),qct.income_time, 120) = SUBSTRING(#{ymd},0,8)
</if>
<if test='ymdType=="dd"'>
and CONVERT(varchar(10),qct.income_time, 120) = SUBSTRING(#{ymd},0,11)
</if>
order by qct.income_time desc,qct.check_status asc
</select>
<select id="getSupplierNoOkList" resultType="com.op.quality.domain.QcInterface">
select
qct.check_no checkNo,
qct.income_batch_no incomeBatchNo,
qct.order_no orderNo,
qct.material_name materialName,
qct.quality,
qct.unit,
qct.supplier_name supplierName,
qct.income_time incomeTime,
qct.check_result checkResult,
qct.check_man_name checkManName,
qc.check_name checkName
from qc_check_task qct
left join qc_check_type qc on qct.check_type = qc.order_code
where qct.type_code = #{typeCode} and qct.check_result = 'N'
<if test='ymdType=="yyyy"'>
and CONVERT(varchar(4),qct.income_time, 120) = SUBSTRING(#{ymd},0,5)
</if>
<if test='ymdType=="mm"'>
and CONVERT(varchar(7),qct.income_time, 120) = SUBSTRING(#{ymd},0,8)
</if>
<if test='ymdType=="dd"'>
and CONVERT(varchar(10),qct.income_time, 120) = SUBSTRING(#{ymd},0,11)
</if>
order by qct.income_time desc
</select>
</mapper>

@ -24,8 +24,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
qct.supplier_code supplierCode,qct.supplier_name supplierName,
count(0) batchs,sum(qct.quality) nums
from qc_check_task qct
left join qc_check_type qc on qc.order_code = qct.check_type
where qc.type_code = #{qc.typeCode}
where qct.type_code = #{qc.typeCode}
and qct.del_flag = '0'
and CONVERT(varchar(7),qct.income_time, 120) = #{qc.yearMonth}
<if test="qc.checkResult != null">
@ -44,8 +43,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
qct.supplier_code supplierCode,qct.supplier_name supplierName,
sum(qct.noOk_quality) noOkNums
from qc_check_task qct
left join qc_check_type qc on qc.order_code = qct.check_type
where qc.type_code = #{qc.typeCode}
where qct.type_code = #{qc.typeCode}
and qct.del_flag = '0'
and CONVERT(varchar(7),qct.income_time, 120) = #{qc.yearMonth}
<if test="codes != null and codes.size()>0">
@ -66,8 +64,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
qct.cNoOkquality,
qct.income_time
from qc_check_task qct
left join qc_check_type qc on qc.order_code = qct.check_type
where qct.del_flag = '0' and qc.type_code = 'produce'
where qct.del_flag = '0' and qct.type_code = 'produce'
<if test="materialCode != null "> and qct.material_code in (${materialCode})</if>
<if test="workCenter != null "> and qct.supplier_code = #{workCenter}</if>
<if test="ymArrayStart != null "> and CONVERT(varchar(10),qct.income_time, 120) >= #{ymArrayStart}</if>
@ -77,8 +74,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
select distinct qct.material_code materialCode,
qct.material_name materialName
from qc_check_task qct
left join qc_check_type qc on qc.order_code = qct.check_type
where qct.del_flag = '0' and qc.type_code = 'produce'
where qct.del_flag = '0' and qct.type_code = 'produce'
<if test="materialCode != null "> and qct.material_code in (${materialCode})</if>
<if test="workCenter != null "> and qct.supplier_code = #{workCenter}</if>
<if test="ymArrayStart != null "> and CONVERT(varchar(10),qct.income_time, 120) >= #{ymArrayStart}</if>
@ -95,8 +91,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
sum(qct.cNoOkquality) cNoOkquality,
CONVERT(varchar(7),qct.income_time, 120) incomeTime
from qc_check_task qct
left join qc_check_type qc on qc.order_code = qct.check_type
where qct.del_flag = '0' and qc.type_code = 'produce'
where qct.del_flag = '0' and qct.type_code = 'produce'
<if test="materialCode != null "> and qct.material_code in (${materialCode})</if>
<if test="workCenter != null "> and qct.supplier_code = #{workCenter}</if>
<if test="ymArrayStart != null "> and CONVERT(varchar(10),qct.income_time, 120) >= #{ymArrayStart}</if>

@ -53,6 +53,9 @@ public class SapController extends BaseController {
@Autowired
private SapBomMapper sapBomMapper;
@Autowired
private SapWmsService sapWmsService;
/**====================主数据相关===================================================================================*/
/**
*
@ -377,12 +380,18 @@ public class SapController extends BaseController {
}
/**
* 退 262
* 261
* @param sapMaterialPostingList
* @return
*/
@PostMapping("/sapMaterialPosting")
@Log(title = "订单物料领料过账、原材料补料、订单物料退料过账接口MB1A", businessType = BusinessType.SAP)
public R sapMaterialPosting(@RequestBody SapMaterialPosting sapMaterialPosting){
return sapItemSyncService.sapMaterialPosting(sapMaterialPosting);
public R sapMaterialPosting(@RequestBody List<SapMaterialPosting> sapMaterialPostingList){
return sapItemSyncService.sapMaterialPosting(sapMaterialPostingList);
}
@ -396,6 +405,44 @@ public class SapController extends BaseController {
return sapOrderService.sapPurchaseOrderSync(sapPurchaseOrderQuery);
}
/**
* 101
*
* @param sapOrderReceiptQuery
* @return
*/
@PostMapping("/sapOrderReceipt")
@Log(title = "智慧工厂101类型订单收货", businessType = BusinessType.SAP)
public R sapOrderReceipt(@RequestBody SapOrderReceiptQuery sapOrderReceiptQuery){
return sapOrderService.sapOrderReceipt(sapOrderReceiptQuery);
}
/**================================WMS=============================*/
/**
*
* @param map
* @return
*/
@PostMapping("/sapLgortInfo")
@Log(title = "智慧工厂储位信息", businessType = BusinessType.SAP)
public R sapLgortInfo(@RequestBody(required = false) Map<String, Object> map){
return sapWmsService.sapLgortInfo(map);
}
/**
* 线
*ZMES_201_MB1A
* ZMES_961_MB1A
* ZMES_962_MB1A
* @param
* @return
*/
@PostMapping("/sapProductWarehousing")
@Log(title = "成品下线入库", businessType = BusinessType.SAP)
public R sapProductWarehousing(@RequestBody(required = false) List<Map<String, Object>> mapList){
return sapWmsService.sapProductWarehousing(mapList);
}
}

@ -0,0 +1,81 @@
package com.op.sap.domain.vo;
/**
* AUFNR CHAR12
* LGORT CHAR4
* ERFMG QUAN-13-3
* CHARG CHAR10
* HSDAT DATS8
* ERFME UNIT
* auth YangWL
*/
public class SapOrderReceiptQuery {
private String aufnr;
private String lgort;
private String erfmg;
private String charg;
private String hsdat;
private String erfme;
public String getAufnr() {
return aufnr;
}
public void setAufnr(String aufnr) {
this.aufnr = aufnr;
}
public String getLgort() {
return lgort;
}
public void setLgort(String lgort) {
this.lgort = lgort;
}
public String getErfmg() {
return erfmg;
}
public void setErfmg(String erfmg) {
this.erfmg = erfmg;
}
public String getCharg() {
return charg;
}
public void setCharg(String charg) {
this.charg = charg;
}
public String getHsdat() {
return hsdat;
}
public void setHsdat(String hsdat) {
this.hsdat = hsdat;
}
public String getErfme() {
return erfme;
}
public void setErfme(String erfme) {
this.erfme = erfme;
}
@Override
public String toString() {
return "SapOrderReceiptQuery{" +
"aufnr='" + aufnr + '\'' +
", lgort='" + lgort + '\'' +
", erfmg='" + erfmg + '\'' +
", charg='" + charg + '\'' +
", hsdat='" + hsdat + '\'' +
", erfme='" + erfme + '\'' +
'}';
}
}

@ -1,10 +1,9 @@
package com.op.sap.service;
import com.op.common.core.domain.R;
import com.op.sap.domain.vo.SapBackflushMPQuery;
import com.op.system.api.domain.sap.SapBackflushMPQuery;
import com.op.sap.domain.vo.SapItemQuery;
import com.op.sap.domain.vo.SapMaterialPosting;
import com.op.system.api.domain.sap.SapBaseProduct;
import com.op.system.api.domain.sap.SapMaterialPosting;
import java.util.List;
@ -21,11 +20,11 @@ public interface SapItemSyncService {
/**
* 退MB1A
* @param sapMaterialPosting
* @param sapMaterialPostingList
* @return
*/
R sapMaterialPosting(SapMaterialPosting sapMaterialPosting);
R sapMaterialPosting(List<SapMaterialPosting> sapMaterialPostingList);
R sapBackflushMP(List<SapBackflushMPQuery> sapBackflushMPQueryList);
}

@ -2,7 +2,9 @@ package com.op.sap.service;
import com.op.common.core.domain.R;
import com.op.sap.domain.vo.SapOrderReceiptQuery;
import com.op.sap.domain.vo.SapPurchaseOrderQuery;
import com.op.system.api.domain.sap.SapCloseOrderQuery;
import com.op.system.api.domain.sap.SapCreateOrder;
import com.op.system.api.domain.sap.SapRFW;
@ -50,4 +52,8 @@ public interface SapOrderService {
R sapPurchaseOrderSync(SapPurchaseOrderQuery sapPurchaseOrderQuery);
R shopUpdateSync(SapShopOrderQuery sapProOrder);
R sapOrderReceipt(SapOrderReceiptQuery sapOrderReceiptQuery);
}

@ -0,0 +1,13 @@
package com.op.sap.service;
import com.op.common.core.domain.R;
import java.util.List;
import java.util.Map;
public interface SapWmsService {
R sapLgortInfo(Map<String, Object> map);
R sapProductWarehousing(List<Map<String, Object>> mapList);
}

@ -9,14 +9,12 @@ import com.op.common.core.utils.DateUtils;
import com.op.common.core.utils.StringUtils;
import com.op.common.core.utils.bean.BeanValidators;
import com.op.common.security.utils.SecurityUtils;
import com.op.sap.domain.vo.SapBackflushMPQuery;
import com.op.system.api.domain.sap.SapBackflushMPQuery;
import com.op.sap.domain.vo.SapItemQuery;
import com.op.sap.domain.vo.SapMaterialPosting;
import com.op.system.api.domain.sap.SapMaterialPosting;
import com.op.sap.mapper.SapBaseProductMapper;
import com.op.sap.service.SapItemSyncService;
import com.op.sap.util.SAPConnUtils;
import com.op.system.api.RemoteUserService;
import com.op.system.api.domain.SysUser;
import com.op.system.api.domain.sap.SapBaseProduct;
import com.sap.conn.jco.*;
import org.slf4j.Logger;
@ -28,6 +26,7 @@ import org.springframework.stereotype.Service;
import javax.validation.Validator;
import java.math.BigDecimal;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
@ -225,7 +224,7 @@ public class SapItemSyncImpl implements SapItemSyncService {
}
@Override
public R sapMaterialPosting(SapMaterialPosting sapMaterialPosting) {
public R sapMaterialPosting(List<SapMaterialPosting> sapMaterialPostingList) {
try {
// 获取调用 RFC 函数对象
@ -233,90 +232,71 @@ public class SapItemSyncImpl implements SapItemSyncService {
// JCoDestination dest = SAPConnUtils.connect();
JCoRepository repository = dest.getRepository();
JCoFunction func = repository.getFunction("ZPPR_MES_GOODSMVT_CREATE");
if (func == null) {
throw new RuntimeException("Function does not exist in SAP");
}
log.info("订单物料开始过账----------------------------------------");
// 配置传入参数
JCoTable jCoTable = func.getTableParameterList().getTable("L_ITEM");
System.out.println(jCoTable);
JCoTable L_ITEM = func.getTableParameterList().getTable("L_ITEM");
for (SapMaterialPosting smp:sapMaterialPostingList){
L_ITEM.appendRow();
//订单号
L_ITEM.setValue("AUFNR",smp.getAufnr());
//移动类型
L_ITEM.setValue("BWART",smp.getBwart());
//工厂
L_ITEM.setValue("PLANT",smp.getPlant());
//总帐科目编号
L_ITEM.setValue("GL_ACCOUNT",smp.getGl_account());
//成本中心
L_ITEM.setValue("COSTCENTER",smp.getCostcenter());
//收货方/运达方
L_ITEM.setValue("GR_RCPT",smp.getGr_rcpt());
//库存地点
L_ITEM.setValue("LGORT",smp.getLgort());
//物料号
L_ITEM.setValue("MATNR",smp.getMatnr());
//数量
L_ITEM.setValue("QUANTITY",smp.getQuantity());
//基本计量单位
L_ITEM.setValue("MEINS",smp.getMeins());
//批号
L_ITEM.setValue("BATCH",smp.getBatch());
JCoParameterList AUFNR = func.getImportParameterList();
System.out.println(AUFNR);
//订单
if (!StringUtils.isNull(sapMaterialPosting.getAufnr())){
// AUFNR.appendRow();
// AUFNR.setValue(Constants.SIGN, "I");
// AUFNR.setValue(Constants.OPTION, "EQ");
// AUFNR.setValue(Constants.LOW, sapMaterialPosting.getAufnr());
}
// //移动类型
// if (!StringUtils.isNull(sapMaterialPosting.getBwart())){
// JCoTable S_MATNR = func.getTableParameterList().getTable("BWART");
// S_MATNR.appendRow();
// S_MATNR.setValue(Constants.SIGN, "I");
// S_MATNR.setValue(Constants.OPTION, "EQ");
// S_MATNR.setValue(Constants.LOW, sapMaterialPosting.getBwart());
// }
// //工厂
// if (!StringUtils.isNull(sapMaterialPosting.getPlant())){
// JCoTable S_MATNR = func.getTableParameterList().getTable("PLANT");
// S_MATNR.appendRow();
// S_MATNR.setValue(Constants.SIGN, "I");
// S_MATNR.setValue(Constants.OPTION, "EQ");
// S_MATNR.setValue(Constants.LOW, sapMaterialPosting.getPlant());
// }
// /**
// * 物料信息
// */
// if (!StringUtils.isNull(sapMaterialPosting.getMatnr())){
// JCoTable S_MATNR = func.getTableParameterList().getTable("MATNR");
// S_MATNR.appendRow();
// S_MATNR.setValue(Constants.SIGN, "I");
// S_MATNR.setValue(Constants.OPTION, "EQ");
// S_MATNR.setValue(Constants.LOW, sapMaterialPosting.getMatnr());
// }
// //数量
// if (!StringUtils.isNull(sapMaterialPosting.getQuantity())){
// JCoTable S_MATNR = func.getTableParameterList().getTable("QUANTITY");
// S_MATNR.appendRow();
// S_MATNR.setValue(Constants.SIGN, "I");
// S_MATNR.setValue(Constants.OPTION, "EQ");
// S_MATNR.setValue(Constants.LOW, sapMaterialPosting.getQuantity());
// }
// //单位
// if (!StringUtils.isNull(sapMaterialPosting.getMeins())){
// JCoTable S_MATNR = func.getTableParameterList().getTable("MEINS");
// S_MATNR.appendRow();
// S_MATNR.setValue(Constants.SIGN, "I");
// S_MATNR.setValue(Constants.OPTION, "EQ");
// S_MATNR.setValue(Constants.LOW, sapMaterialPosting.getMeins());
// }
// //批号
// JCoTable S_MATNR = func.getTableParameterList().getTable("BATCH");
// S_MATNR.appendRow();
// S_MATNR.setValue(Constants.SIGN, "I");
// S_MATNR.setValue(Constants.OPTION, "EQ");
// S_MATNR.setValue(Constants.LOW, sapMaterialPosting.getBatch());
// 获取调用 RFC 函数对象
func.execute(dest);
// 获取 内表 - ZMES_PRO
JCoTable maraTable = func.getTableParameterList().getTable("LT_RETURN");
JCoRecordMetaData metaData = maraTable.getRecordMetaData();
System.out.println("###" + metaData.toString());
for (int i = 0; i < maraTable.getNumRows(); i++) {
maraTable.setRow(i);
String RETCODE = maraTable.getString("RETCODE");
System.out.println(RETCODE);
}
// JCoRecordMetaData metaData = maraTable.getRecordMetaData();
// System.out.println("###" + metaData.toString());
if (func == null) {
throw new RuntimeException("Function does not exist in SAP");
func.execute(dest);
JCoTable maraTable = func.getTableParameterList().getTable("LT_RETURN");
JCoRecordMetaData metaData = maraTable.getRecordMetaData();
System.out.println("###" + metaData.toString());
StringBuilder Msg = new StringBuilder();
for (int i = 0; i < maraTable.getNumRows(); i++) {
maraTable.setRow(i);
String TYPE = maraTable.getString("TYPE");
String MESSAGE = maraTable.getString("MESSAGE");
Msg.append(MESSAGE+"/");
System.out.println("TYPE:"+TYPE);
System.out.println("MESSAGE:"+MESSAGE);
}
String L_MSG= func.getExportParameterList().getString("L_MSG");
String RETCODE= func.getExportParameterList().getString("RETCODE");
String MATERIALDOCUMENT= func.getExportParameterList().getString("MATERIALDOCUMENT");
String MATDOCUMENTYEAR= func.getExportParameterList().getString("MATDOCUMENTYEAR");
System.out.println("L_MSG"+L_MSG);
System.out.println("返回值0-没有错误1-有错误:"+RETCODE);
System.out.println("物料凭证编号"+MATERIALDOCUMENT);
System.out.println("物料凭证年度"+MATDOCUMENTYEAR);
if (!("0").equals(RETCODE)){
return R.fail("",Msg.toString());
}else {
Map map=new HashMap();
map.put("MATERIALDOCUMENT",MATERIALDOCUMENT);
map.put("MATDOCUMENTYEAR",MATDOCUMENTYEAR);
return R.ok(map,Msg.toString());
}
return R.ok();
}catch (Exception e){
return R.fail(e.getMessage());
}
@ -330,6 +310,7 @@ public class SapItemSyncImpl implements SapItemSyncService {
@Override
public R sapBackflushMP(List<SapBackflushMPQuery> sapBackflushMPQueryList) {
try {
JCoRepository repository = dest.getRepository();
JCoFunction func = repository.getFunction("ZPPR_MES_GOODSMVT_CREATE_B");
@ -338,7 +319,7 @@ public class SapItemSyncImpl implements SapItemSyncService {
}
JCoTable L_ITEM = func.getTableParameterList().getTable("L_ITEM");
System.out.println(L_ITEM);
// System.out.println(L_ITEM);
//
// int successNum = 0;
@ -375,23 +356,37 @@ public class SapItemSyncImpl implements SapItemSyncService {
JCoTable maraTable = func.getTableParameterList().getTable("LT_RETURN");
JCoRecordMetaData metaData = maraTable.getRecordMetaData();
System.out.println("###" + metaData.toString());
StringBuilder Msg = new StringBuilder();
for (int i = 0; i < maraTable.getNumRows(); i++) {
maraTable.setRow(i);
String TYPE = maraTable.getString("TYPE");
System.out.println(TYPE);
String MESSAGE = maraTable.getString("MESSAGE");
Msg.append(MESSAGE+"/");
System.out.println("TYPE:"+TYPE);
System.out.println("MESSAGE:"+MESSAGE);
}
String L_MSG= func.getExportParameterList().getString("L_MSG");
String RETCODE= func.getExportParameterList().getString("RETCODE");
String MATERIALDOCUMENT= func.getExportParameterList().getString("MATERIALDOCUMENT");
String MATDOCUMENTYEAR= func.getExportParameterList().getString("MATDOCUMENTYEAR");
System.out.println("L_MSG"+L_MSG);
System.out.println("返回值0-没有错误1-有错误:"+RETCODE);
System.out.println("物料凭证编号"+MATERIALDOCUMENT);
System.out.println("物料凭证年度"+MATDOCUMENTYEAR);
if (!("0").equals(RETCODE)){
return R.fail("",Msg.toString());
}else {
Map map=new HashMap();
map.put("MATERIALDOCUMENT",MATERIALDOCUMENT);
map.put("MATDOCUMENTYEAR",MATDOCUMENTYEAR);
return R.ok(map,Msg.toString());
}
System.out.println(L_MSG);
System.out.println(RETCODE);
System.out.println(MATERIALDOCUMENT);
System.out.println(MATDOCUMENTYEAR);
return R.ok();
// System.out.println("MATERIALDOCUMENT"+MATERIALDOCUMENT);
// System.out.println("MATDOCUMENTYEAR"+MATDOCUMENTYEAR);
//
// return R.ok();
}catch (Exception e){
return R.fail(e.getMessage());

@ -7,10 +7,10 @@ import com.op.common.core.utils.DateUtils;
import com.op.common.core.utils.StringUtils;
import com.op.common.core.utils.uuid.IdUtils;
import com.op.sap.domain.vo.SapOrderReceiptQuery;
import com.op.sap.domain.vo.SapPurchaseOrderQuery;
import com.op.sap.service.SapOrderService;
import com.op.sap.util.SAPConnUtils;
import com.op.system.api.domain.sap.SapCloseOrderQuery;
import com.op.system.api.domain.sap.SapCreateOrder;
import com.op.system.api.domain.sap.SapRFW;
@ -59,6 +59,7 @@ public class SapOrderServiceImpl implements SapOrderService {
// 配置传入参数
// S_WERKS(工厂) S_AUFNR订单号 S_MATNR物料号 S_ERDAT(创建日期) 例如20230923
if (!StringUtils.isNull(sapShopOrderQuery.getWerk())){
JCoTable S_WERKS = func.getTableParameterList().getTable("S_PWERK");
S_WERKS.appendRow();
@ -183,13 +184,15 @@ public class SapOrderServiceImpl implements SapOrderService {
jCoParameterList.setValue("P_DATEE",sapCreateOrder.getDatee());
func.execute(dest);//执行调用函数
JCoParameterList J= func.getExportParameterList();
// System.out.println(J);
System.out.println(func.getExportParameterList());
L_MSG= func.getExportParameterList().getString("L_MSG");
String LV_ORDER_NUMBER= func.getExportParameterList().getString("LV_ORDER_NUMBER");
// String RETCODE = func.getExportParameterList().getString("RETCODE");
//String LV_ORDER_NUMBER= func.getExportParameterList().getString("LV_ORDER_NUMBER");
// if (RETCODE.equals(Constants.FAIL)){
// return R.fail(LV_ORDER_NUM_List,L_MSG);
// }
JCoTable LT_ZGD=func.getTableParameterList().getTable("LT_ZGD");
// System.out.println(LT_ZGD);
//DynamicDataSourceContextHolder.push("ds_1000");//controller已经完成切换
for (int i = 0; i <LT_ZGD.getNumRows(); i++) {
LT_ZGD.setRow(i);
Map map=new HashMap();
@ -199,8 +202,10 @@ public class SapOrderServiceImpl implements SapOrderService {
map.put("AUFNR",AUFNR);
LV_ORDER_NUM_List.add(map);
}
}
log.info("订单创建结果----"+L_MSG+"|"+JSONObject.toJSONString(LV_ORDER_NUM_List));
return R.ok(LV_ORDER_NUM_List,L_MSG);
}else {
log.error("接收的数据为空");
@ -292,7 +297,7 @@ public class SapOrderServiceImpl implements SapOrderService {
* LT_GS
*/
JCoTable LT_GS_jCoTable = func.getTableParameterList().getTable("LT_GS");
System.out.println("LT_GS_jCoTable"+LT_GS_jCoTable);
// System.out.println("LT_GS_jCoTable"+LT_GS_jCoTable);
LT_GS_jCoTable.appendRow();
LT_GS_jCoTable.setValue("CONF_ACTIVITY1", sapRFW.getLt_gs().getConf_activity1());
LT_GS_jCoTable.setValue("CONF_ACTIVITY2", sapRFW.getLt_gs().getConf_activity2());
@ -304,7 +309,7 @@ public class SapOrderServiceImpl implements SapOrderService {
* MES LT_HW
*/
JCoTable LT_HW_jCoTable = func.getTableParameterList().getTable("LT_HW");
System.out.println("LT_HW_jCoTable"+LT_HW_jCoTable);
//System.out.println("LT_HW_jCoTable"+LT_HW_jCoTable);
for (SapRFW.lt_hw lt_hw:sapRFW.getLt_hwList()){
LT_HW_jCoTable.appendRow();
LT_HW_jCoTable.setValue("MATERIAL", lt_hw.getMaterial());
@ -314,9 +319,10 @@ public class SapOrderServiceImpl implements SapOrderService {
func.execute(dest);//执行调用函数
JCoParameterList J= func.getExportParameterList();
System.out.println(J);
//System.out.println(J);
String RETCODE= func.getExportParameterList().getString("RETCODE");
MESSAGE= func.getExportParameterList().getString("MESSAGE");
if (StringUtils.contains(MESSAGE,"错误")){
if (Constants.FAIL.equals(RETCODE)){
return R.fail("订单号:"+sapRFW.getAufnr()+"报工失败"+MESSAGE);
}
return R.ok("",MESSAGE);
@ -475,7 +481,80 @@ public class SapOrderServiceImpl implements SapOrderService {
}
}
@Override
public R sapOrderReceipt(SapOrderReceiptQuery sapOrderReceiptQuery) {
try {
log.info("智慧工厂101类型订单收货入参-------"+sapOrderReceiptQuery.toString());
JCoRepository repository = dest.getRepository();
JCoFunction func = repository.getFunction("ZMES_101_MIGO");
//System.out.println(jCoParameterList);
if (func == null) {
throw new RuntimeException("Function does not exist in SAP");
}
if (StringUtils.isEmpty(sapOrderReceiptQuery.getAufnr()))
{
return R.fail("订单号为空!");
}
if (StringUtils.isEmpty(sapOrderReceiptQuery.getLgort()))
{
return R.fail("库位为空!");
}
if (StringUtils.isEmpty(sapOrderReceiptQuery.getErfmg()))
{
return R.fail("数量为空!");
}
if (StringUtils.isEmpty(sapOrderReceiptQuery.getCharg()))
{
return R.fail("批号为空!");
}
if (StringUtils.isEmpty(sapOrderReceiptQuery.getHsdat()))
{
return R.fail("生产日期为空!");
}
// 配置传入参数
JCoTable L_ITEM = func.getTableParameterList().getTable("L_ITEM");
L_ITEM.appendRow();
// System.out.println(L_ITEM);
L_ITEM.setValue("AUFNR",sapOrderReceiptQuery.getAufnr());
L_ITEM.setValue("WERKS","1000");
L_ITEM.setValue("LGORT",sapOrderReceiptQuery.getLgort());
L_ITEM.setValue("QUANTITY",sapOrderReceiptQuery.getErfmg());
L_ITEM.setValue("BATCH",sapOrderReceiptQuery.getCharg());
L_ITEM.setValue("HSDAT",sapOrderReceiptQuery.getHsdat());
L_ITEM.setValue("ERFME",sapOrderReceiptQuery.getErfme());
func.execute(dest);//执行调用函数
// System.out.println(func.getExportParameterList());
String RETCODE= func.getExportParameterList().getString("RETCODE");
String MESSAGE= func.getExportParameterList().getString("L_MSG");
String MATERIALDOCUMENT= func.getExportParameterList().getString("MATERIALDOCUMENT");
if ((Constants.FAIL).equals(Integer.parseInt(RETCODE))){
log.error("订单收货结果-----"+MESSAGE);
return R.fail(null,"订单号:"+sapOrderReceiptQuery.getAufnr()+MESSAGE);
}else {
log.info("订单收货结果-----"+MESSAGE);
return R.ok(MATERIALDOCUMENT,"订单号:"+sapOrderReceiptQuery.getAufnr()+MESSAGE);
}
}catch (Exception e){
log.error(e.getMessage());
return R.fail(e.getMessage());
}
}
// public static void main(String[] args) {
// List<SapBackflushMPQuery> sapBackflushMPQueryList=new ArrayList<>();
// SapBackflushMPQuery sapBackflushMPQuery=new SapBackflushMPQuery();
// sapBackflushMPQuery.setMatnr("000000020000000280");
// sapBackflushMPQuery.setPlant("1000");
// sapBackflushMPQuery.setLgort("0013");
// sapBackflushMPQuery.setQuantity("3600");
// sapBackflushMPQuery.setMeins("ST");
// sapBackflushMPQueryList.add(sapBackflushMPQuery);
// System.out.println(JSONObject.toJSONString(sapBackflushMPQueryList));
// }
}

@ -13,6 +13,8 @@ import com.op.sap.service.SapRouterService;
import com.op.sap.util.SAPConnUtils;
import com.op.system.api.domain.sap.*;
import com.sap.conn.jco.*;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import org.springframework.stereotype.Service;
@ -27,6 +29,7 @@ import java.util.stream.Collectors;
@Component
@Service
public class SapRouterServiceImpl implements SapRouterService {
private static final Logger log = LoggerFactory.getLogger(SapOrderServiceImpl.class);
private static final String END_DATE="99991231";
@Autowired
private SapProProcessMapper sapProProcessMapper;
@ -70,6 +73,7 @@ public class SapRouterServiceImpl implements SapRouterService {
S_AEDAT
*/
log.info("工艺路线同步入参-------"+sapRouterQuery.toString());
if (!StringUtils.isNull(sapRouterQuery.getMatnr())){
JCoTable S_MATNR = func.getTableParameterList().getTable("S_MATNR");
S_MATNR.appendRow();
@ -118,7 +122,7 @@ public class SapRouterServiceImpl implements SapRouterService {
// 获取 内表 - ZMES_PRO
JCoTable maraTable = func.getTableParameterList().getTable("LT_ROUTING");
JCoRecordMetaData metaData = maraTable.getRecordMetaData();
System.out.println("###" + metaData.toString());
// System.out.println("###" + metaData.toString());
List<SapProRoute> sapProRouteList=new ArrayList<>();
//DynamicDataSourceContextHolder.push("ds_1000");//controller已经完成切换
for (int i = 0; i <maraTable.getNumRows(); i++) {
@ -168,7 +172,7 @@ public class SapRouterServiceImpl implements SapRouterService {
String SPMUS = maraTable.getString("SPMUS");
String SPLIM = maraTable.getString("SPLIM");
String CKSELKZ = maraTable.getString("CKSELKZ");
System.out.println(
log.info(
"工厂:" + WERKS+
"任务清单类型:" + PLNTY+
"任务清单组码:" + PLNNR+
@ -354,14 +358,16 @@ public class SapRouterServiceImpl implements SapRouterService {
if (failureNum > 0)
{
failureMsg.insert(0, "很抱歉,同步失败!共 " + failureNum + " 工艺路线异常,错误如下:");
failureMsg.insert(0, "很抱歉,同步失败!共 " + failureNum + " 工艺路线异常");
log.error(failureMsg.toString());
throw new ServiceException(failureMsg.toString());
}
else
{
successMsg.insert(0, "恭喜您,数据同步成功!共 " + successNum + " 条,数据如下:");
successMsg.insert(0, "恭喜您,数据同步成功!共 " + successNum + " 条");
}
}catch (Exception e){
log.error(e.getMessage());
return R.fail(e.getMessage());
}
return R.ok(successMsg);

@ -0,0 +1,208 @@
package com.op.sap.service.impl;
import com.op.common.core.domain.R;
import com.op.common.core.utils.StringUtils;
import com.op.sap.service.SapWmsService;
import com.sap.conn.jco.*;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import org.springframework.stereotype.Service;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
@Component
@Service
public class SapWmsServicelmpl implements SapWmsService {
private static final Logger log = LoggerFactory.getLogger(SapWmsServicelmpl.class);
@Autowired
private JCoDestination dest;
@Override
public R sapLgortInfo(Map<String, Object> map) {
try {
JCoRepository repository = dest.getRepository();
JCoFunction func = repository.getFunction("ZMES_GET_LGORT");
if (func == null) {
throw new RuntimeException("Function does not exist in SAP");
}
log.info("获取储位信息入参-------"+map.toString());
if (!StringUtils.isNull(map.get("S_WERKS"))){
JCoTable S_MATNR = func.getTableParameterList().getTable("S_WERKS");
S_MATNR.appendRow();
S_MATNR.setValue("SIGN", "I");
S_MATNR.setValue("OPTION", "EQ");
S_MATNR.setValue("LOW", map.get("S_WERKS"));
}
func.execute(dest);//执行调用函数
// 获取 内表 - ZMES_PRO
JCoTable maraTable = func.getTableParameterList().getTable("LT_LGORT");
/**
* WERKS
* LGORT
* LGOBE
* ZTYPE
*/
List<Map> mapList=new ArrayList<>();
for (int i = 0; i <maraTable.getNumRows(); i++) {
maraTable.setRow(i);
String WERKS = maraTable.getString("WERKS");
String LGORT = maraTable.getString("LGORT");
String LGOBE = maraTable.getString("LGOBE");
String ZTYPE = maraTable.getString("ZTYPE");
log.info("工厂:" + WERKS+
"库存地点:" + LGORT+
"仓储地点的描述:" + LGOBE+
"已冻结标识:" + ZTYPE);
Map entyMap=new HashMap();
entyMap.put("WERKS",WERKS);
entyMap.put("LGORT",LGORT);
entyMap.put("LGOBE",LGOBE);
entyMap.put("ZTYPE",ZTYPE);
mapList.add(entyMap);
}
return R.ok(mapList);
}catch (Exception e){
log.error(e.getMessage());
return R.fail(e.getMessage());
}
}
@Override
public R sapProductWarehousing(List<Map<String, Object>> mapList) {
try {
JCoRepository repository = dest.getRepository();
JCoFunction func = repository.getFunction("ZMES_PRODUCT_MB1A");
if (func == null) {
throw new RuntimeException("Function does not exist in SAP");
}
log.info("成品移动ZMES_PRODUCT_MB1A-------"+mapList.toString());
/**
AUFNR
POSNR
BWART
PLANT
LGORT
KOSTL
MATNR
QUANTITY
MEINS
BATCH
HSDAT
VFDAT 寿
*/
JCoTable L_ITEM = func.getTableParameterList().getTable("L_ITEM");
System.out.println(L_ITEM);
System.out.println( L_ITEM.getNumRows());
for (int i=1;i<10;i++){
L_ITEM.appendRow();
L_ITEM.setValue("AUFNR", "01234567890"+String.valueOf(i));
L_ITEM.setValue("POSN", "012"+String.valueOf(i));
L_ITEM.setValue("POSN", "012"+String.valueOf(i));
L_ITEM.setValue("POSN", "012"+String.valueOf(i));
}
System.out.println(L_ITEM);
// if (!StringUtils.isNull(map.get("AUFNR"))){
// JCoTable S_MATNR = func.getTableParameterList().getTable("AUFNR");
// S_MATNR.appendRow();
// S_MATNR.setValue("SIGN", "I");
// S_MATNR.setValue("OPTION", "EQ");
// S_MATNR.setValue("LOW", map.get("AUFNR"));
// }
// if (!StringUtils.isNull(map.get("POSNR"))){
// JCoTable S_MATNR = func.getTableParameterList().getTable("POSNR");
// S_MATNR.appendRow();
// S_MATNR.setValue("SIGN", "I");
// S_MATNR.setValue("OPTION", "EQ");
// S_MATNR.setValue("LOW", map.get("POSNR"));
// }
// if (!StringUtils.isNull(map.get("BWART"))){
// JCoTable S_MATNR = func.getTableParameterList().getTable("BWART");
// S_MATNR.appendRow();
// S_MATNR.setValue("SIGN", "I");
// S_MATNR.setValue("OPTION", "EQ");
// S_MATNR.setValue("LOW", map.get("BWART"));
// }
// if (!StringUtils.isNull(map.get("PLANT"))){
// JCoTable S_MATNR = func.getTableParameterList().getTable("PLANT");
// S_MATNR.appendRow();
// S_MATNR.setValue("SIGN", "I");
// S_MATNR.setValue("OPTION", "EQ");
// S_MATNR.setValue("LOW", map.get("PLANT"));
// }
// if (!StringUtils.isNull(map.get("LGORT"))){
// JCoTable S_MATNR = func.getTableParameterList().getTable("LGORT");
// S_MATNR.appendRow();
// S_MATNR.setValue("SIGN", "I");
// S_MATNR.setValue("OPTION", "EQ");
// S_MATNR.setValue("LOW", map.get("LGORT"));
// }
// if (!StringUtils.isNull(map.get("KOSTL"))){
// JCoTable S_MATNR = func.getTableParameterList().getTable("KOSTL");
// S_MATNR.appendRow();
// S_MATNR.setValue("SIGN", "I");
// S_MATNR.setValue("OPTION", "EQ");
// S_MATNR.setValue("LOW", map.get("KOSTL"));
// }
// if (!StringUtils.isNull(map.get("MATNR"))){
// JCoTable S_MATNR = func.getTableParameterList().getTable("MATNR");
// S_MATNR.appendRow();
// S_MATNR.setValue("SIGN", "I");
// S_MATNR.setValue("OPTION", "EQ");
// S_MATNR.setValue("LOW", map.get("MATNR"));
// }
// if (!StringUtils.isNull(map.get("QUANTITY"))){
// JCoTable S_MATNR = func.getTableParameterList().getTable("QUANTITY");
// S_MATNR.appendRow();
// S_MATNR.setValue("SIGN", "I");
// S_MATNR.setValue("OPTION", "EQ");
// S_MATNR.setValue("LOW", map.get("QUANTITY"));
// }
// if (!StringUtils.isNull(map.get("MEINS"))){
// JCoTable S_MATNR = func.getTableParameterList().getTable("MEINS");
// S_MATNR.appendRow();
// S_MATNR.setValue("SIGN", "I");
// S_MATNR.setValue("OPTION", "EQ");
// S_MATNR.setValue("LOW", map.get("MEINS"));
// }
// if (!StringUtils.isNull(map.get("BATCH"))){
// JCoTable S_MATNR = func.getTableParameterList().getTable("BATCH");
// S_MATNR.appendRow();
// S_MATNR.setValue("SIGN", "I");
// S_MATNR.setValue("OPTION", "EQ");
// S_MATNR.setValue("LOW", map.get("BATCH"));
// }
// func.execute(dest);//执行调用函数
// // 获取 内表 - ZMES_PRO
// JCoTable maraTable = func.getTableParameterList().getTable("LT_LGORT");
//
// List<Map> mapList=new ArrayList<>();
// for (int i = 0; i <maraTable.getNumRows(); i++) {
// maraTable.setRow(i);
// String WERKS = maraTable.getString("WERKS");
// String LGORT = maraTable.getString("LGORT");
// String LGOBE = maraTable.getString("LGOBE");
// String ZTYPE = maraTable.getString("ZTYPE");
// log.info("工厂:" + WERKS+
// "库存地点:" + LGORT+
// "仓储地点的描述:" + LGOBE+
// "已冻结标识:" + ZTYPE);
// Map entyMap=new HashMap();
// entyMap.put("WERKS",WERKS);
// entyMap.put("LGORT",LGORT);
// entyMap.put("LGOBE",LGOBE);
// entyMap.put("ZTYPE",ZTYPE);
// mapList.add(entyMap);
// }
return R.ok();
}catch (Exception e){
log.error(e.getMessage());
return R.fail(e.getMessage());
}
}
}

@ -149,6 +149,14 @@ public class OdsProcureOrderController extends BaseController {
return success(wmsRawOrderInSns);
}
/**
*
*/
@ -221,7 +229,7 @@ public class OdsProcureOrderController extends BaseController {
@PostMapping("/InventoryPlanIssuance")
public AjaxResult InventoryPlanIssuance(@RequestBody WCSInventoryPlan wcsInventoryPlan) {
String result= odsProcureOrderService.InventoryPlanIssuance(wcsInventoryPlan);
//托盘状态更新
return success(result);
}
//http://192.168.202.37:9001/api/v1/ReceiveMesMsg/packingMaterialsOutBoundByPallet
@ -237,5 +245,36 @@ public class OdsProcureOrderController extends BaseController {
//托盘状态更新
return success(result);
}
/**
*
* @param odsProcureOutOrder
* @return
*/
@PostMapping("/ProductionMaterialRequisition")
public AjaxResult ProductionMaterialRequisition(@RequestBody OdsProcureOutOrder odsProcureOutOrder) {
List<OdsProcureOutOrder> result= odsProcureOrderService.ProductionMaterialRequisition(odsProcureOutOrder);
return success(result);
}
/**
* --
* @param wmsOdsMateStorageNewsSn
* @return
*/
@PostMapping("/ProductionMaterialRequisitionsn")
public AjaxResult ProductionMaterialRequisitionsn(@RequestBody WmsOdsMateStorageNewsSn wmsOdsMateStorageNewsSn) {
WmsOdsMateStorageNewsSn wmsOdsMateStorageNewsSn1= odsProcureOrderService.ProductionMaterialRequisitionsn(wmsOdsMateStorageNewsSn);
return success(wmsOdsMateStorageNewsSn1);
}
/**
* --
* @param orderList
* @return
*/
@PostMapping("/ProductionMaterialRequisitionAdd")
public AjaxResult ProductionMaterialRequisitionAdd(@RequestBody List<OdsProcureOutOrder> orderList) {
Integer result= odsProcureOrderService.ProductionMaterialRequisitionAdd(orderList);
return success(result);
}
}

@ -118,6 +118,7 @@ public WmsToWCSDTO packingMaterialsOutBoundCompleted(@RequestBody WmsToWCSDTO wc
return success(wmsRawOrderInSns);
}
/**
*
*/
@ -141,13 +142,15 @@ public WmsToWCSDTO packingMaterialsOutBoundCompleted(@RequestBody WmsToWCSDTO wc
return success();
}
/**
*
*
* @param odsProcureOutOrder
* @return
*/
@PostMapping("/sapPurchaseOrderSync")
public R sapPurchaseOrderSync(@RequestBody SapBackflushMPQuery sapPurchaseOrderQuery){
return odsProcureOrderService.sapPurchaseOrderSync(sapPurchaseOrderQuery);
@PostMapping("/ProductionMaterialRequisition")
public AjaxResult ProductionMaterialRequisition(@RequestBody OdsProcureOutOrder odsProcureOutOrder) {
List<OdsProcureOutOrder> result= odsProcureOrderService.ProductionMaterialRequisition(odsProcureOutOrder);
return success(result);
}
}

@ -20,6 +20,15 @@ import com.op.common.core.web.domain.BaseEntity;
@JsonInclude(JsonInclude.Include.NON_NULL)
public class OdsProcureOutOrder extends BaseEntity {
private static final long serialVersionUID = 1L;
private String factoryCode;
public String getFactoryCode() {
return factoryCode;
}
public void setFactoryCode(String factoryCode) {
this.factoryCode = factoryCode;
}
/** 工厂编码 */
@Excel(name = "工厂编码")

@ -14,7 +14,15 @@ public class OrderLine extends BaseEntity {
private BigDecimal qty;//数量
private String qualityStatus;//质检状态1合格2不合格
private String stationNo;//包装线
private String ken;//包装线--如果是用于自动化就选1,如果是手持人工出库就选2
public String getKen() {
return ken;
}
public void setKen(String ken) {
this.ken = ken;
}
private String materialCode;
private String materialDesc;

@ -1,73 +0,0 @@
package com.op.wms.domain;
import java.io.Serializable;
/**
*
* auth YangWL
*
* MATNR CHAR 18 0
* PLANT CHAR 4 0
* GR_RCPT CHAR 12 0 /
* LGORT CHAR 4 0
* UMLGO CHAR 4 0 /
* QUANTITY QUAN 13 3
* MEINS UNIT 3 0
* BATCH CHAR 10 0
* MOVE_BATCH CHAR 10 0 /
*/
public class SapBackflushMPQuery implements Serializable {
/**
* S_EBELN
* S_EBELP
* S_MATNR
* S_PWERK
*/
private String ebeln;
private String ebelp;
private String matnr;
private String pwerk;
private String factoryCode;//
public String getFactoryCode() {
return factoryCode;
}
public void setFactoryCode(String factoryCode) {
this.factoryCode = factoryCode;
}
public String getEbeln() {
return ebeln;
}
public void setEbeln(String ebeln) {
this.ebeln = ebeln;
}
public String getEbelp() {
return ebelp;
}
public void setEbelp(String ebelp) {
this.ebelp = ebelp;
}
public String getMatnr() {
return matnr;
}
public void setMatnr(String matnr) {
this.matnr = matnr;
}
public String getPwerk() {
return pwerk;
}
public void setPwerk(String pwerk) {
this.pwerk = pwerk;
}
}

@ -75,11 +75,17 @@ public interface IOdsProcureOrderService {
OrderLine addPurchaseOrderOutbound(OrderLine orderLine);
R sapPurchaseOrderSync(SapBackflushMPQuery sapPurchaseOrderQuery);
void TraystatusUpdate(WMSTraystatus wmsTraystatus);
String InventoryPlanIssuance(WCSInventoryPlan wcsInventoryPlan);
String DesignatedPalletOutbound(WMSDesignatedPalle wmsDesignatedPalle);
List<OdsProcureOutOrder> ProductionMaterialRequisition(OdsProcureOutOrder odsProcureOutOrder);
Integer ProductionMaterialRequisitionAdd(List<OdsProcureOutOrder> orderList);
WmsOdsMateStorageNewsSn ProductionMaterialRequisitionsn(WmsOdsMateStorageNewsSn wmsOdsMateStorageNewsSn);
}

@ -1,6 +1,6 @@
package com.op.wms.service.impl;
import com.alibaba.csp.sentinel.util.StringUtil;
import com.alibaba.fastjson2.JSONArray;
@ -13,10 +13,11 @@ import java.util.Date;
import java.util.List;
import com.op.common.core.domain.R;
import com.op.common.core.web.domain.AjaxResult;
import okhttp3.OkHttpClient;
import okhttp3.MediaType;
import okhttp3.RequestBody;
@ -204,6 +205,7 @@ public class OdsProcureOrderServiceImpl implements IOdsProcureOrderService {
wmsOdsMateStorageNewsSn.setAmount(wmsRawOrderInSn.getAmount());
wmsOdsMateStorageNewsSn.setCreateBy(wmsRawOrderInSn.getCreateBy());
wmsOdsMateStorageNewsSn.setGmtCreate(new Date());
wmsOdsMateStorageNewsSn.setUserDefined2(wmsRawOrderInSn.getUserDefined2());//批次
wmsOdsMateStorageNewsSn.setFactoryCode(wmsRawOrderInSn.getFactoryCode());
wmsOdsMateStorageNewsSn.setSapFactoryCode(wmsRawOrderInSn.getFactoryCode());
wmsOdsMateStorageNewsSnMapper.insertWmsOdsMateStorageNewsSn(wmsOdsMateStorageNewsSn);
@ -260,135 +262,65 @@ public class OdsProcureOrderServiceImpl implements IOdsProcureOrderService {
public OrderLine addPurchaseOrderOutbound(OrderLine orderLine) {
//自己生成行项目,,批次号
List<OrderLine> orderList= orderLine.getList();
SimpleDateFormat dateFormat = new SimpleDateFormat("yyyyMMddHH:mm:ss");
Date date = new Date();
String formattedDate = dateFormat.format(date);
//根据订单号查询对应的最大批次号
Integer orderItem = 0;
for (OrderLine orderLine1:
orderList) {
orderItem++;
orderLine1.setOrderLineNo(String.format("%05d", orderItem));
orderLine1.setBatchNo("00001");
orderLine1.setBatchNo(formattedDate);
}
String meg= addPurchaseOrderOutboundWCS(orderLine);
if ("OK".equals(meg)){//成功
for (OrderLine orderLine1:
orderList) {
OdsProcureOutOrder odsProcureOutOrder=new OdsProcureOutOrder();
odsProcureOutOrder.setID(IdUtils.fastSimpleUUID());
odsProcureOutOrder.setProduceCode(orderLine.getOrderNo());
odsProcureOutOrder.setMaterialCode(orderLine1.getMaterialCode());
odsProcureOutOrder.setMaterialDesc(orderLine1.getMaterialDesc());
odsProcureOutOrder.setPlanDate(new Date());
odsProcureOutOrder.setUnit(orderLine1.getUnit());
odsProcureOutOrder.setProductionLineCode(orderLine1.getStationNo());
odsProcureOutOrder.setUserDefined1(orderLine1.getBatchNo());
odsProcureOutOrder.setActive("1");
odsProcureOutOrder.setOrderStatus("1");
odsProcureOutOrder.setPlanNumber(orderLine1.getPlanNumber());
odsProcureOutOrder.setUserDefined2(orderLine1.getOrderLineNo());
//odsProcureOutOrder.set
odsProcureOutOrderMapper.insertOdsProcureOutOrder(odsProcureOutOrder);
String ken=orderLine.getKen();
if("2".equals(ken)){
//手持出库
for (OrderLine orderLine1:
orderList) {
OdsProcureOutOrder odsProcureOutOrder=new OdsProcureOutOrder();
odsProcureOutOrder.setID(IdUtils.fastSimpleUUID());
odsProcureOutOrder.setProduceCode(orderLine.getOrderNo());
odsProcureOutOrder.setMaterialCode(orderLine1.getMaterialCode());
odsProcureOutOrder.setMaterialDesc(orderLine1.getMaterialDesc());
odsProcureOutOrder.setPlanDate(new Date());
odsProcureOutOrder.setUnit(orderLine1.getUnit());
odsProcureOutOrder.setProductionLineCode(orderLine1.getStationNo());
odsProcureOutOrder.setUserDefined1(orderLine1.getBatchNo());
odsProcureOutOrder.setActive("1");
odsProcureOutOrder.setOrderStatus("1");
odsProcureOutOrder.setPlanNumber(orderLine1.getPlanNumber());
odsProcureOutOrder.setUserDefined2(orderLine1.getOrderLineNo());
//odsProcureOutOrder.set
odsProcureOutOrderMapper.insertOdsProcureOutOrder(odsProcureOutOrder);
}
}else {
String meg= addPurchaseOrderOutboundWCS(orderLine);
if ("OK".equals(meg)){//成功
for (OrderLine orderLine1:
orderList) {
OdsProcureOutOrder odsProcureOutOrder=new OdsProcureOutOrder();
odsProcureOutOrder.setID(IdUtils.fastSimpleUUID());
odsProcureOutOrder.setProduceCode(orderLine.getOrderNo());
odsProcureOutOrder.setMaterialCode(orderLine1.getMaterialCode());
odsProcureOutOrder.setMaterialDesc(orderLine1.getMaterialDesc());
odsProcureOutOrder.setPlanDate(new Date());
odsProcureOutOrder.setUnit(orderLine1.getUnit());
odsProcureOutOrder.setProductionLineCode(orderLine1.getStationNo());
odsProcureOutOrder.setUserDefined1(orderLine1.getBatchNo());
odsProcureOutOrder.setActive("1");
odsProcureOutOrder.setOrderStatus("1");
odsProcureOutOrder.setPlanNumber(orderLine1.getPlanNumber());
odsProcureOutOrder.setUserDefined2(orderLine1.getOrderLineNo());
//odsProcureOutOrder.set
odsProcureOutOrderMapper.insertOdsProcureOutOrder(odsProcureOutOrder);
}
}
}
return orderLine;
}
@Override
public R sapPurchaseOrderSync(SapBackflushMPQuery sapPurchaseOrderQuery) {
// DynamicDataSourceContextHolder.push("ds_" + sapPurchaseOrderQuery.getFactoryCode());
// try {
// // 获取调用 RFC 函数对象
// //获取连接
// //JCoDestination dest = SAPConnUtils.connect();
// JCoRepository repository = dest.getRepository();
// JCoFunction func = repository.getFunction("ZMES_GET_PROCURE");
// JCoParameterList jCoParameterList= func.getTableParameterList();
// System.out.println(jCoParameterList);
// if (func == null) {
// throw new RuntimeException("Function does not exist in SAP");
// }
// /** S_EBELN 采购订单号
// * S_EBELP 行项目
// * S_MATNR 物料号
// * S_PWERK 工厂
// */
// if (!StringUtils.isNull(sapPurchaseOrderQuery.getEbeln())){
// JCoTable S_EBELN = func.getTableParameterList().getTable("S_EBELN");
// S_EBELN.appendRow();
// S_EBELN.setValue(Constants.SIGN, "I");
// S_EBELN.setValue(Constants.OPTION, "EQ");
// S_EBELN.setValue(Constants.LOW, sapPurchaseOrderQuery.getEbeln());
// }
//// if (!StringUtils.isNull(sapPurchaseOrderQuery.getEbeln())){
//// JCoTable S_EBELN = func.getTableParameterList().getTable("S_EBELP");
//// S_EBELN.appendRow();
//// S_EBELN.setValue(Constants.SIGN, "I");
//// S_EBELN.setValue(Constants.OPTION, "EQ");
//// S_EBELN.setValue(Constants.LOW, sapPurchaseOrderQuery.getEbeln());
//// }
//// if (!StringUtils.isNull(sapPurchaseOrderQuery.getMatnr())){
//// JCoTable S_MATNR = func.getTableParameterList().getTable("S_MATNR");
//// S_MATNR.appendRow();
//// S_MATNR.setValue(Constants.SIGN, "I");
//// S_MATNR.setValue(Constants.OPTION, "EQ");
//// S_MATNR.setValue(Constants.LOW, sapPurchaseOrderQuery.getMatnr());
//// }
////
//// if (!StringUtils.isNull(sapPurchaseOrderQuery.getPwerk())){
//// JCoTable S_PWERK = func.getTableParameterList().getTable("S_PWERK");
//// S_PWERK.appendRow();
//// S_PWERK.setValue(Constants.SIGN, "I");
//// S_PWERK.setValue(Constants.OPTION, "EQ");
//// S_PWERK.setValue(Constants.LOW, sapPurchaseOrderQuery.getPwerk());
//// }
// func.execute(dest);//执行调用函数
// // 获取 内表 - LT_PROCURE
// JCoTable maraTable = func.getTableParameterList().getTable("LT_PROCURE");
// JCoRecordMetaData metaData = maraTable.getRecordMetaData();
// System.out.println("###" + metaData.toString());
//
// List<OdsProcureOrder> sapCustomList=new ArrayList<>();
// for (int i = 0; i <maraTable.getNumRows(); i++) {
// maraTable.setRow(i);
// OdsProcureOrder odsProcureOrder=new OdsProcureOrder();
// String EBELN = maraTable.getString("EBELN");//订单号
// String EBELP = maraTable.getString("EBELP");//行项目
// String MATNR = maraTable.getString("MATNR");//物料号
// String MAKTX = maraTable.getString("MAKTX");//物料描述(短文本
// String MENGE = maraTable.getString("MENGE");//采购订单数量
// String MEINS = maraTable.getString("MEINS");//采购订单的计量单位
// String ZMENGE = maraTable.getString("ZMENGE");//交货数量
// String ZMEINS = maraTable.getString("ZMEINS");//基本计量单位
// String LIFNR = maraTable.getString("LIFNR");//供应商帐户号
// String WERKS = maraTable.getString("WERKS");//工厂
// //String LGORT = maraTable.getString("LGORT");//库存地点
// //String EINDT = maraTable.getString("EINDT");//项目交货日期
// //String ELIKZ = maraTable.getString("ELIKZ");//交货已完成标识
// //String BEIZHU = maraTable.getString("BEIZHU");//注释
// odsProcureOrder.setSiteCode(WERKS);
// odsProcureOrder.setProcureCode(EBELN);
// odsProcureOrder.setMaterialCode(MATNR);
// odsProcureOrder.setMaterialDesc(MAKTX);
// odsProcureOrder.setOrderStatus("0");
// //odsProcureOrder.setPlanDate();
// odsProcureOrder.setPlanNumber(new BigDecimal(MENGE));
// odsProcureOrder.setUserDefined1(ZMENGE);
// odsProcureOrder.setUserDefined2(ZMEINS);
// odsProcureOrder.setSupplierCode(LIFNR);
// odsProcureOrder.setCreateBy("task");
// odsProcureOrder.setCreateDate(new Date());
// odsProcureOrder.setActive("1");
// odsProcureOrder.setUnit(MEINS);
// odsProcureOrderMapper.insertOdsProcureOrder(odsProcureOrder);
// }
// return R.ok();
// }catch (Exception e){
// return R.fail(e.getMessage());
// }
return R.ok();
}
@Override
public void TraystatusUpdate(WMSTraystatus wmsTraystatus) {
@ -496,6 +428,35 @@ public class OdsProcureOrderServiceImpl implements IOdsProcureOrderService {
return result;
}
@Override
public List<OdsProcureOutOrder> ProductionMaterialRequisition(OdsProcureOutOrder odsProcureOutOrder) {
DynamicDataSourceContextHolder.push("ds_" + odsProcureOutOrder.getFactoryCode());
List<OdsProcureOutOrder> orderList= odsProcureOutOrderMapper.selectOdsProcureOutOrderList(odsProcureOutOrder);
return orderList;
}
@Override
public Integer ProductionMaterialRequisitionAdd(List<OdsProcureOutOrder> orderList) {
//修改对应订单--插入对应出库托盘数据数据
// for (OdsProcureOutOrder odsProcureOutOrder:
// orderList) {
// //领料单,物料编号,物料名称,托盘号,出库数量,库位号,
// odsProcureOutOrder.
// }
return null;
}
@Override
public WmsOdsMateStorageNewsSn ProductionMaterialRequisitionsn(WmsOdsMateStorageNewsSn wmsOdsMateStorageNewsSn) {
DynamicDataSourceContextHolder.push("ds_" + wmsOdsMateStorageNewsSn.getFactoryCode());
WmsToWCSDTO wmsToWCSDTO=new WmsToWCSDTO();
wmsToWCSDTO.setRfidNo(wmsOdsMateStorageNewsSn.getSn());
WmsOdsMateStorageNewsSn wmsOdsMateStorageNewsSn1= wmsOdsMateStorageNewsSnMapper.selectwmsRfidNotwo(wmsToWCSDTO);
return wmsOdsMateStorageNewsSn1;
}
public String DesignatedPalletOutboundWCS(WMSDesignatedPalle wmsDesignatedPalle){
// 定义请求的URL地址
String url = "http://192.168.202.37:9001/api/v1/ReceiveMesMsg/packingMaterialsOutBoundByPallet";

@ -1,6 +1,7 @@
package com.op.wms.service.impl;
import com.baomidou.dynamic.datasource.annotation.DS;
import com.baomidou.dynamic.datasource.toolkit.DynamicDataSourceContextHolder;
import com.op.common.core.utils.uuid.IdUtils;
import com.op.wms.domain.*;
import com.op.wms.mapper.*;
@ -29,6 +30,7 @@ public class WmsToWCSInterfaceServiceImpl implements IWmsToWCSInterfaceService {
@Override
@DS("#header.poolName")
public WmsToWCSDTO requestMaterialLoadNo(WmsToWCSDTO wcsdto) {
DynamicDataSourceContextHolder.push("ds_" + wcsdto.getFactory());
WmsToWCSDTO wmsToWCSDTO= wmsToWCSInterfaceMapper.selectWmsToWCSDTO(wcsdto);
// wmsToWCSDTO.set//
wmsToWCSDTO.setCode("0");
@ -46,6 +48,8 @@ public class WmsToWCSInterfaceServiceImpl implements IWmsToWCSInterfaceService {
@Override
@DS("#header.poolName")
public WmsToWCSDTO blankStorageOrTransferCompleted(WmsToWCSDTO wcsdto) {
DynamicDataSourceContextHolder.push("ds_" + wcsdto.getFactory());
WmsOdsWhiteEmbryoIn wmsOdsWhiteEmbryoIn1=new WmsOdsWhiteEmbryoIn();
//rfidNo-托盘
WmsToWCSDTO wmsToWCSDTO= wmsToWCSInterfaceMapper.selectWmsToWCSDTO(wcsdto);
@ -61,11 +65,9 @@ public class WmsToWCSInterfaceServiceImpl implements IWmsToWCSInterfaceService {
boolean ten = sum.compareTo(planNumber) >= 0; // 判断sum是否大于等于planNumber
if (ten) {
wmsOdsWhiteEmbryoIn1.setOrderStatus("1");
} else {
//小于
wmsOdsWhiteEmbryoIn1.setOrderStatus("2");
}
wmsOdsWhiteEmbryoIn1.setRealityNumber(sum);///操作数量+已入数量
//1,修改订单

@ -218,14 +218,14 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<select id="selectmesPrepare" parameterType="OdsProcureOutOrder" resultMap="OdsProcureOutOrderResult">
SELECT
prepare_id id,
workorder_code Produce_Code,
workorder_name Produce_Code,
product_code Material_Code,
product_name Material_Desc,
unit Unit,
product_date Plan_Date,
prod_type User_Defined1
FROM mes_prepare WHERE
workorder_code =#{produceCode}
workorder_name =#{produceCode}
</select>
<select id="selectmesPrepareDetail" parameterType="OdsProcureOutOrder" resultMap="OdsProcureOutOrderResult">

@ -9,7 +9,7 @@ import org.springframework.security.web.authentication.SavedRequestAwareAuthenti
/**
*
*
*
* @author OP
*/
@EnableWebSecurity

Loading…
Cancel
Save