生产订单状态

  • 数据库表 
表名描述
AUFK订单主数据表,包含订单的基本信息。
JEST工单状态表,存储了订单的状态信息STAT,包括系统状态(I)和用户状态(E),状态是否有效(字段INACT,X-无效,空-有效)
TJ02T状态文本说明表,包含状态的描述信息
TJ02系统状态表,包含状态是否显示在前台等配置信息
  • 函数
  • STATUS_READ:读取生产订单的所有状态信息
 SELECT SINGLE OBJNR INTO P_OBJNR FROM AUFK WHERE AUFNR = P_AUFNR.
  IF SY-SUBRC EQ 0.
    CALL FUNCTION 'STATUS_READ'
      EXPORTING
        OBJNR                 = P_OBJNR
       STONR                  = P_STONR
     TABLES
       STATUS                 = LT_STATUS
     EXCEPTIONS
        OBJECT_NOT_FOUND       = 1
        OTHERS                 = 2.
  ENDIF.

  •  STATUS_TEXT_EDIT:读取生产订单的所有状态信息,返回参数 LINE会将,订单状态拼接成一个字符串,这个字符串是在前台订单上看到的状态。
   lv_objnr = |OR{ gs_upload-aufnr }|.
      CALL FUNCTION 'STATUS_TEXT_EDIT'
        EXPORTING
          client           = sy-mandt
          flg_user_stat    = ' '
          objnr            = lv_objnr
          only_active      = 'X'
          spras            = 'E'
          bypass_buffer    = ' '
        IMPORTING
          line             = lv_line
        EXCEPTIONS
          object_not_found = 1
          OTHERS           = 2.

  • STATUS_CHECK: 检查生产订单是否有某个特定的状态
  • 订单状态 
状态描述备注
CRTD创建生产订单刚刚创建,此时禁止做后续发料和报工确认等操作
PREL部分下达如下达部分工序时出现此状态
REL已下达这个状态后可以继续后续业务操作,如打印订单、发料、报完工等操作
MANC未检查物料可用性生产订单未进行零部件物料的可用性检查
SETC 结算规则维护生产订单已维护结算规则
MSPT物料短缺零部件物料在进行可用性检查后发现存在短缺
MACM已承诺的物料零部件物料在进行可用性检查后确认完全可用
GMPS已过帐的货物移动生产订单已经进行过发料
PCNF部分确认生产订单只进行了部分完工确认
PDLV部分交货生产订单只有部分产品入库
DLV已完全交货生产订单已经完全交货入库,月末,系统根据订单的状态,判断是计算差异还是计算在制品。如果订单具有DLV或TECO状态,结算差异;如果没有这两个状态,订单结算在制品。
VCAL差异计算生产订单进行过差异运算
TECO技术完成在生产过程中,会出现订单未完成但是不再继续生产的情况,这时就可以打上技术完结标识,同时订单对零部件的需求同时删除
RESA进行结果分析生产订单进行过结算
CLSD关闭生产订单做账务关闭,不允许对订单发生任何过账
DLT删除对生产订单做删除标识,数据仍然存在数据库中,状态可恢复。如果想彻底删除,需对订单进行归档处理
在SAP ABAP中,获取生产订单状态通常可以通过以下几种方式实现: 1. **使用标准事务代码**: - **COOIS**:生产订单信息系统,可以查询和显示生产订单的状态。 2. **使用ABAP程序**: 通过编写ABAP程序,可以直接从数据库表中获取生产订单的状态。常用的表包括: - **AFKO**:生产订单的总体数据。 - **AFPO**:生产订单的项目数据。 - **JEST**:状态管理。 以下是一个简单的ABAP程序示例,用于获取生产订单的状态: ```abap REPORT z_get_prod_order_status. PARAMETERS: p_aufnr TYPE aufk-aufnr OBLIGATORY. DATA: ls_afko TYPE afko, ls_afpo TYPE afpo, ls_jest TYPE jest, lv_stat TYPE jest-stat. SELECT SINGLE * FROM afko INTO ls_afko WHERE aufnr = p_aufnr. IF sy-subrc = 0. SELECT SINGLE * FROM afpo INTO ls_afpo WHERE aufnr = p_aufnr. IF sy-subrc = 0. SELECT SINGLE * FROM jest INTO ls_jest WHERE objnr = ls_afpo-objnr AND stat = 'I0002'. IF sy-subrc = 0. lv_stat = ls_jest-stat. WRITE: / '生产订单状态:', lv_stat. ELSE. WRITE: / '未找到生产订单状态'. ENDIF. ELSE. WRITE: / '未找到生产订单项目数据'. ENDIF. ELSE. WRITE: / '未找到生产订单总体数据'. ENDIF. ``` 3. **使用函数模块**: SAP提供了许多函数模块来获取生产订单的状态,例如: - **STATUS_READ**:读取对象的状态。 - **BAPI_PRODORD_GETSTATUS**:获取生产订单的状态。 以下是一个使用函数模块的示例: ```abap REPORT z_get_prod_order_status_func. PARAMETERS: p_aufnr TYPE aufk-aufnr OBLIGATORY. DATA: lt_status TYPE TABLE OF bapi_proddord_status, ls_status TYPE bapi_proddord_status, lv_return TYPE bapiret2. CALL FUNCTION 'BAPI_PRODORD_GETSTATUS' EXPORTING productionorder = p_aufnr TABLES status = lt_status return = lv_return. IF lv_return-type = 'E'. WRITE: / '错误:', lv_return-message. ELSE. LOOP AT lt_status INTO ls_status. WRITE: / '生产订单状态:', ls_status-status. ENDLOOP. ENDIF. ``` 通过以上几种方法,您可以在SAP ABAP中获取生产订单的状态。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值