[英]Error while creating sales order using JCO with BAPI_SALESORDER_CREATEFROMDAT2
I am trying to create a sales order using BAPI_SALESORDER_CREATEFROMDAT2 butI am getting error “No customer master record exists for customer 99” when I tried to create a sales order for customer 99(example) with the partner Role 'AG','WE' where both 'sold-to-party and ship-to-party' are mandatory fields. 我正在尝试使用BAPI_SALESORDER_CREATEFROMDAT2创建销售订单,但是当我尝试与合作伙伴角色'AG','WE'为客户99(示例)创建销售订单时,出现错误“客户99没有客户主记录” “售达方”和“寄达方”都是必填字段。 If I send “SP” it will ask me to define 'sold-to-party and ship-to-party' ,Please let me know if I have to send some different partner roles to be able to create a sales order.
如果我发送“ SP”,它将要求我定义“售出方和发运方”,请告知我是否必须发送一些其他合作伙伴角色才能创建销售订单。
public static void createSalesOrder() {
try {
JCoDestination destination = JCoDestinationManager.getDestination("ABAP_AS_WITH_POOL");
JCoFunction functionCreateOrder = destination.getRepository().getFunction("BAPI_SALESORDER_CREATEFROMDAT2");
JCoFunction functionTransComit = destination.getRepository().getFunction("BAPI_TRANSACTION_COMMIT");
JCoStructure orderHeaderIn = functionCreateOrder.getImportParameterList().getStructure("ORDER_HEADER_IN");
orderHeaderIn.setValue("SALES_ORG", "2000");
orderHeaderIn.setValue("DISTR_CHAN", "20");
orderHeaderIn.setValue("DIVISION", "20");
orderHeaderIn.setValue("DOC_TYPE", "ZAR");
JCoTable orderPartners = functionCreateOrder.getTableParameterList().getTable("ORDER_PARTNERS");
// WE,AG,SP,PH
// AG Sold to Party
// WE Ship to Party
orderPartners.appendRows(1);
orderPartners.setValue("PARTN_ROLE", "AG");
orderPartners.setValue("PARTN_NUMB", "99");
orderPartners.appendRows(1);
orderPartners.setValue("PARTN_ROLE", "WE");
orderPartners.setValue("PARTN_NUMB", "99");
System.out.println(orderPartners);
JCoTable orderItemsIn = functionCreateOrder.getTableParameterList().getTable("ORDER_ITEMS_IN");
orderItemsIn.appendRow();
orderItemsIn.setValue("MATERIAL", "PEN_ARN");
System.out.println(orderItemsIn);
JCoTable orderSchedulesIn = functionCreateOrder.getTableParameterList().getTable("ORDER_SCHEDULES_IN");
orderSchedulesIn.appendRow();
orderSchedulesIn.setValue("REQ_QTY", "1");
System.out.println(orderSchedulesIn);
functionCreateOrder.execute(destination);
functionTransComit.execute(destination);
// System.out.println(functionCreateOrder);
JCoTable returnTable = functionCreateOrder.getTableParameterList().getTable("RETURN");
System.out.println(returnTable.getString("MESSAGE"));
System.out.println("sales order number is : "
+ functionCreateOrder.getExportParameterList().getValue("SALESDOCUMENT"));
} catch (JCoException ex) {
System.out.println(ex.getMessage());
} finally {
System.out.println("Creating sales order ends");
}
}
问题是与合作伙伴的数目有关,如果领先于合作伙伴数目的数为000000000,就可以解决问题。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.