5

我正在使用 JCo 库来访问 SAP 标准 BAPI。好吧,除了当我使用 TID (TransactionID) 时返回表始终为空之外,一切都正常工作。

当我只是删除 TID 时,我得到的 RETURN 表中充满了警告等。但不幸的是,我需要将 TID 用于事务性 BAPI,否则不会提交更改。

为什么使用 TID 时 RETURN TABLE 为空?

或者我必须如何提交对事务 BAPI 的更改?

这里是 BAPI 访问的伪代码:

import com.sap.conn.jco.*;
import org.apache.commons.logging.*;

public class BapiSample {

    private static final Log logger = LogFactory.getLog(BapiSample.class);
    private static final String CLIENT = "400";
    private static final String INSTITUTION = "1000";
    protected JCoDestination destination;

    public BapiSample() {
        this.destination = getDestination("mySAPConfig.properties");
    }

    public void execute() {
        String tid = null;
        try {
            tid = destination.createTID();
            JCoFunction function = destination.getRepository().getFunction("BAPI_PATCASE_CHANGEOUTPATVISIT");

            function.getImportParameterList().setValue("CLIENT", CLIENT);
            function.getImportParameterList().setValue("INSTITUTION", INSTITUTION);
            function.getImportParameterList().setValue("MOVEMNT_SEQNO", "0001");
            // Here we will then all parameters of the BAPI....
            // ...
            // Now the execute
            function.execute(destination, tid);
            // And getting the RETURN Table. !!! THIS IS ALWAYS EMPTY!
            JCoTable returnTable = function.getTableParameterList().getTable("RETURN");
            int numRows = returnTable.getNumRows();
            for (int i = 0; i < numRows; i++) {
                returnTable.setRow(i);
                logger.info("RETURN VALUE: " + returnTable.getString("MESSAGE"));
            }
            JCoFunction commit = destination.getRepository().getFunction("BAPI_TRANSACTION_COMMIT");
            commit.execute(destination, tid);
            destination.confirmTID(tid);
        } catch (Throwable ex) {
            try {
                if (destination != null) {
                    JCoFunction rollback = destination.getRepository().getFunction("BAPI_TRANSACTION_ROLLBACK");
                    rollback.execute(destination, tid);
                }

            } catch (Throwable t1) {
            }
        }
    }

    protected static JCoDestination getDestination(String fileName) {
        JCoDestination result = null;
        try {
            result = JCoDestinationManager.getDestination(fileName);
        } catch (Exception ex) {
            logger.error("Error during destination resolution", ex);
        }
        return result;
    }
}

更新 10.01.2013:我终于能够得到两者,返回表填充和输入提交。解决方案是两者都做,没有 TID 的提交,获取 RETURN 表,然后再次使用 TID 提交。

非常非常奇怪,但也许是 JCo Commits 的正确用法。谁可以给我解释一下这个?

4

2 回答 2

2

我能够同时获得 RETURN 表填充和输入提交。

解决方案是两者都做,没有 TID 的提交,获取 RETURN 表,然后再次使用 TID 提交

于 2015-05-13T09:12:25.827 回答
1

你不应该调用execute方法2次,它会增加序列号你应该在JCoContext类中使用begin和end方法。

如果在流程开始时调用 begin 方法,数据将被更新并返回消息。这是示例代码。

  JCoDestination destination = JCoDestinationManager.getDestination("");
  try
  {
      JCoContext.begin(destination);
      function.execute(destination)
      function.execute(destination)
  } 
  catch (AbapException ex)
  {
         ...
  } 
  catch (JCoException ex)
  {
         ...
  }  
  catch (Exception ex)
  {
         ...
  }
  finally
  {
      JCoContext.end(destination);
  }

您可以参考此 URL 的更多信息。 http://www.finereporthelp.com/download/SAP/sapjco3_linux_32bit/javadoc/com/sap/conn/jco/JCoContext.html

于 2015-10-14T09:56:30.153 回答