热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

CHAPTER7各部之间的关系及程序举例

一.各部之间的关系:IDENTIFICATIONDIVISION.PROGRAM-ID.PROGRAM1
一.各部之间的关系:
IDENTIFICATION   DIVISION.
PROGRAM-ID.        PROGRAM1.
给程序加上标识以便识别.
ENVIRONMENT  DIVISION.
CONFIGRATION   SECTION.
INPUT-OUTPUT    SECTION.
FILE-CONTROL.
        SELECT    PRODFILE  ASSIGN  TO FILE1.
描述程序中用到的文件与外部文件的关系及控制信息
DATA  DIVISION.
FILE   SECTION.
FD    PRODFILE    LABEL  RECORD  IS  STANDARD.
01     PROD-REC      PIC      X(200).  
WORKING-STORAGE   SECTION.
01     WS-VARIBALES.
         05   WS-I          PIC      9(2).
描述程序中用到的所有文件及其记录中各数据项的属性及程序中用到的所有中间数据项的描述.
PROCEDURE  DIVISION. 程序的核心部分,他决定计算机进行什么操作.如,文件的读写及其他处理


二.程序举例:
例1:
读入一组产品销售记录,每读入一个记录,计算出销售总额(数量X单价).然后打印出该产品的全部数据.数据形式如下:

1  9  9  2  1  2  3  1  0  0  0  0  0  1  A  A  A  A  0  1  0  0  5  0  0  0
1  9  9  3  1  2  3  1  1  0  0  0  0  1  B  B  B B  0  2  0  0  6  0  0  0
-------------------------  -----------------   ------------  ------------  -----------
         DATE                PRODCODE     CUST        AMT        PRICE
程序如下:
IDENTIFICATION       DIVISION.
PROGRAM-ID.             PEXAM1
ENVIRONMENT          DIVISION.
CONFIGRATION         SECTION.
INPUT-OUTPUT          SECTION.
FILE-CONTROL.
        SELECT     INPUT-FILE         ASSIGN    TO     FILE1
                           ORGANIZATION                    IS      SEQUENCIAL
                           ACCESS    MODE                    IS      SEQUENCIAL
                           FILE-STATUS                          IS     WS-INPUT-FILE-STATUS.
        SELECT    OUTPUT-FILE        ASSIGN  TO     P-FILE
                           ORGANIZATION                    IS      SEQUENCIAL
                           ACCESS    MODE                    IS      SEQUENCIAL
                           FILE-STATUS                          IS     WS-OUTPUT-FILE-STATUS.
DATA                           DIVISION.
FILLE                           SECTION.
FD      INPUT-FILE       LABEL     RECORD    IS     STANDARD.
01       IN-REC.
           05      DATE            PIC    9(8). 
           05      PROD-CODE  PIC    9(6).
           05      CUSTOMER-CODE  PIC    X(4).
           05      QUANTITY  PIC    9(4).
           05      UNIT-PRICE     PIC    9(4).
FD      OUTPUT-FILE       LABEL     RECORD    IS     STANDARD.
01       OUT-REC.
           05      DATE            PIC    9999B99B99. 
           05      FILLER   PIC    X(5).
           05      PROD-CODE  PIC    9(6).
           05      FILLER   PIC    X(5). 
           05      CUSTOMER-CODE PIC    X(4).
           05      FILLER   PIC    X(5).
           05      QUANTITY  PIC    ZZZ9.
           05      FILLER   PIC    X(5).          
           05      UNIT-PRICE           PIC    $(5).
           05      FILLER          PIC    X(5).
           05      SALES-VALUE      PIC    $(8).

WORKING-STORAGE                SECTION.
01       WS-VARIBLES.
           05      WS-INPUT-FILE-STATUS  PIC    9(2).
                     88       WS-INPUT-FILE-SUCCESSFUL         VALUE     0.
                     88       WS-INPUT-FILE-EOF                          VALUE    23.
           05      WS-OUTPUT-FILE-STATUS PIC    9(2).
                     88       WS-OUTPUT-FILE-SUCCESSFUL     VALUE     0.   
PROCEDURE                                DIVISION.

A000-MAIN.
          PERFORM         A100-OPEN-FILES         
          PERFORM         R000-READ-FILE            
          PERFORM         A200-PROCESS-RECORD UNTIL WS-INPUT-FILE-EOF
          PERFORM         A300-CLOSE-FILES           
          STOP RUN
          .
A000-EXIT.
          EXIT
          .

A100-OPEN-FILES.
           OPEN INPUT        INPUT-FILE
                          OUTPUT    OUTPUT-FILE
           IF     NOT           WS-INPUT-FILE-SUCCESSFUL     
 DISPLAY   ‘INPUT-FILE              OPEN     NOT   SUCCESSFUL’    UPON    CONSOLE
 PERFORM  Z000-ABEND
          END-IF 
           IF     NOT            WS-OUTPUT-FILE-SUCCESSFUL     
 DISPLAY   ‘OUTPUT-FILE         OPEN      NOT   SUCCESSFUL’    UPON    CONSOLE
 PERFORM  Z000-ABEND      
           END-IF 
          .
A200-PROCESS-RECORD.
           INITIALIZE  OUT-REC
           MOVE           CORR         IN-REC     TO           OUT-REC
           COMPUTE   SALES-VALUE   =  QUANTITY  OF  IN-REC   *   UNIT-PRICE   OF   OUT-REC
           PERFORM   W000-WRITE-FILE 
           PERFORM    R000-READ-FILE    
           .
A300-CLOSE-FILE.
           CLOSE         INPUT-FILE          
                                 OUTPUT-FILE
           .
R000-READ-FILE.
           READ  INPUT-FILE
           IF     NOT   WS-INPUT-FILE-SUCCESSFUL   AND  NOT    WS-INPUT-FILE-EOF  
 DISPLAY   ‘INPUT-FILE  READ NOT   SUCCESSFUL’    UPON    CONSOLE
 PERFORM  Z000-ABEND            THRU      Z000-EXIT
           END-IF
          .

W000-WRITE-FILE.
           WRITE  OUT-REC         AFTER     1
           IF     NOT   WS-OUTPUT-FILE-SUCCESSFUL    
 DISPLAY   ‘OUTPUT-FILE  WRITE  NOT   SUCCESSFUL’    UPON    CONSOLE
 PERFORM  Z000-ABEND 
           END-IF
           .
Z000-ABEND.
          DISPLAY   ‘PROGRAM   ABEND !’    UPON    CONSOLE
          PERFORM  A300-CLOSE-FILES          THRU    A300-EXIT
          MOVE         16                                         TO         RETURN-CODE
          GOBACK
          .

输出的数据形式如下:
1992 12 31     000001     AAAA      100      $5000      $500000

1993 12 31     100001     BBBB       200      $6000      $1200000


例2:
Program : INVI300    Update  inventory   file (random)
                          

File   Description  Use 
VALTRAN  Valid inventory transaction  file Input
INVMAST Inventory  master  file Update
ERRTRAN Unmatched inventory transaction file Output
 
Process specifications
        This program updates an inventory master file (INVMAST) based on the data in a sequential
file of valid inventory transaction records (VALTRAN). The inventory master file is indexed  by item number and updated randomly.

        If the program finds a master record with the same item number as a transaction, it uses the
transaction data to update the master record .It does this by increasing the on hand quantity
in the master record by the receipt quantity in the transaction record.
        If the program cannot find a master record for a transaction, it writes the transaction record on
the file of error transactions (ERRTRAN). The record format format for ERRTRAN is same as
for VALTRAN.

The basic processing requirements are:

1. Read a transaction record.

2. Read the master record with the same item number as in the transaction record.

3. If the master  record is found , update and rewrite the matching master record.

4. If the transaction is not found , write the transaction record on the file of error  transactions.

程序如下:
IDENTIFICATION DIVISION.
PROGRAM-ID. INV1300.

ENVIRONENT  DIVISON.
INPUT-OUTPUT  SECTION.
FILE-CONTROL.
        SELECT  VALTRAN    ASSIGN  TO   SYS020-AS-VALTRAN.
        SELECT  INVMAST     ASSIGN  TO   SYS021-INVMAT
              ORGANIZATION IS  INDEXED
              ACCESS                 IS    RANDOM
              RECORD KEY       IS   MR-ITEM-NO
              FILE STATUS        IS   INVMAST-ERROR-CODE.
         SELECT  ERRTRAN    ASSIGN  TO   SYS022-AS-ERRTRAN.

DATA  DIVISION.
FILE  SECTION.
FD    VALTRAN
         LABEL  RECORDS  ARE  STANDARD.
01     VALID-TRANSACTION-AREA  PIC  X(21).
FD    INVMAST
         LABEL RECORDS  ARE  STANDARD.
01     MASTER-RECORD-AREA.
         05   MR-ITEM-NO  PIC  X(5).
         05   FILLER   PIC  X(45).
FD    ERRTRAN
         LABEL  RECORDS ARE STANDARD.
01     ERROR-TRANSACTION  PIC  X(21).
WORKING-STORAGE SECTION.
01    SWITCHES.
        05    VALTRAN-EOF-SWITCH PIC  X   VALUE  ‘N’.
                88    VALTRAN-EOF                                  VALUE  ‘Y’.
        05    MASTER-FOUND-SWITCH PIC  X.
                88    MASTER-FOUND                               VALUE  ‘Y’.

01    FILE-STATUS-FIELD.
        05    INVMAST-ERROR-CODE PIC  X(2).

01    INVENTROY-TRANSACTION-RECORD.
        05    IT-ITEM-NO  PIC  X(5).
        05    IT-VENOR-NO  PIC  X(5).
        05    IT-RECEIPT-DATE  PIC  X(6).
        05    IT-RECEIPT-QUANTITY             PIC  S9(5).
01    INVENTORY-MASTER-RECORD.
        05    IM-DESCRIPTIVE-DATA.
                10    IM-ITEM-NO  PIC  X(5).
                10    IM-ITEM-DESC  PIC  X(20).
                10    IM-UNIT-COST  PIC  S9(3)V9(2).
                10    IM-UNIT-PRICE         PIC  S9(3)V9(2).
        05    IM-INVENTORY-DATA.
                10    IM-REORDER-POINT PIC  S9(5).
                10    IM-ON-HAND  PIC  S9(5).
                10    IM-ON-ORDER  PIC  S9(5).  
PROCEDURE DIVISION.
A000-UPDATE-INVENTORY-FILE.
         OPEN             INPUT        VALTRAN
                                I-O               INVMAST
                                OUTPUT     ERRTRAN
         PERFORM    B000-PROCESS-INVENTORY-TRAN      THRU     B000-EXIT
                                UNTIL         VALTRAN-EOF
         CLOSE                  VALTRAN
                   INVMAST
                   ERRTRAN
         DISPLAY      ‘PROGRAM   INV1300  NORMAL  END’
         GOBACK.
B000-PROCESS-INVENTORY-TRAN.
        PERFORM                      B100-READ-INVENTORY-TRAN              
        IF      NOT                       VALTRAN-EOF
                  PERFORM            B200-READ-INVENTORY-MASTER         
                  IF     MASTER-FOUND
                           PERFORM   B300-UPDATE-INVENTORY-MASTER    
                  ELSE
                           PERFORM   B400-WRITE-ERROR-TRAN                       
                  END-IF
        END-IF.
B000-EXIT.
        EXIT.
                  
B100-READ-INVENTRORY-TRAN.
        READ   VALTRAN        INTO    INVENTORY-TRANSACTION-RECORD
                     AT   END           MOVE  ‘Y’         TO        VALTRAN-EOF-SWITCH.
B100-EXIT.
        EXIT.


B200-READ-INVENTORY-MASTER.
        MOVE   IT-ITEM-NO                                    TO         MR-ITEM-NO
        READ    INVMASST                                      INTO    INVENTORY-MASTER-RECORD
        IF           INVMAST-ERROR-CODE              = ‘00’
                      MOVE  ‘Y’                                        TO         MASTER-FOUND-SWITCH
        ELSE   
                      MOVE  ‘N’                                        TO         MASTER-FOUND-SWITCH
        END-IF.

B300-UPDATE-INVENTORY-MASTER.
        ADD     IT-RECEIPT-QUANTITY                TO          IM-ON-HAND
        REWRITE  MASTER-RECORD-AREA       FROM    INVENTORY-MASTER-RECORD
        IF          INVMAST-ERROR-CODE              NOT       =   ‘00’
                     DISPLAY   ‘ INV1300  REWRITE   INVMAST ERROR . ITEM  NUMBER = ’ IM-ITEM-NO
                     DISPLAY   ‘ FILE  STATUS    = ’    INVMAST-ERROR-CODE
                     MOVE  ‘Y’                                         TO         VALTRAN-EOF-SWITH
        END-IF.
B300-EXIT.
        EXIT.

B400-WRITE-ERROR-TRAN.
        WRITE   ERROR-TRANSACTION                FROM   INVENTORY-TRANSACTION-RECORD.
B400-EXIT.
        EXIT.     
       IDENTIFICATION DIVISION.
       PROGRAM-ID.    PROGRAM3.
      
       ENVIRONMENT DIVISION.
     
       DATA DIVISION.
       WORKING-STORAGE SECTION.

       01  WS-RESP    PIC S9(8)  COMP.   
           88  WS-RESP-NORMAL   VALUE  0.

       01  PGM3COM.
    05  CUST-NO  PIC  9(8).
    05  PGM3-OUT.
                        10  PGM3-RETURN-CODE PIC  X(2).
               88  PGM3-SUCCESSFUL                    VALUE '  '.
                                88  PGM3-CUST-NBR-ERR                VALUE '01'.
                88  PGM3-CUST-NOT-FND               VALUE '02'. 
         10  PGM3-AC   PIC  9(5).
         10  PGM3-BAL   PIC  9(11).  

 01  MASTER-RECORD.
       05  MASTER-KEY      PIC  9(8).
       05  CUST-NAME    PIC  X(20).
       05  CHECK-AC    PIC  9(5).
       05  BAL    PIC  9(11).          
LINKAGE SECTION.
     
01  DFHCOMMAREA                    PIC  X(26).
    
PROCEDURE DIVISION.
     
A000-MAIN-PROCESS.
 
         MOVE  DFHCOMMAREA       TO      PGM3COM
          
         INITIALIZE PGM3-OUT

         PERFORM B000-VALIDATION      THRU B000-EXIT
         IF      PGM3-SUCCESSFUL
                  PERFORM C000-PROCESS    THRU C000-EXIT
        END-IF
        .
      
 A999-RETURN.
           MOVE PGM3COM                 TO   DFHCOMMAREA.
           EXEC CICS        RETURN     END-EXEC.
           GOBACK.
      *
 B000-VALIDATION.
           IF   CUST-NO       NOT  NUMERIC
                SET PGM3-CUST-NBR-ERR    TO   TRUE
           END-IF
           .
  B000-EXIT.
           EXIT.
      *
      
C000-PROCESS.
           MOVE CUST-NO                  TO   MASTER-KEY
           EXEC CICS READ FILE  ('VMASTER')
                      RIDFLD(MASTER-KEY)
                      INTO  (MASTER-RECORD)
                      LENGTH(LENGTH OF MASTER-RECORD)
     RESP  (WS-RESP)
                      END-EXEC
           IF  WS-RESP    NOT            =    DFHRESP(NORMAL)   
        IF  WS-RESP              =    DFHRESP(NOTFND)    
               SET  PGM3-CUST-NOT-FND  TO   TRUE
        ELSE
               EXEC   CICS  ABEND  ABCODE('ABCD')   END-EXEC
        END-IF 
           ELSE
        MOVE CHECK-AC            TO   PGM3-AC
        MOVE BAL   TO   PGM3-BAL    
           END-IF
           .
 C000-EXIT.
           EXIT.
     


推荐阅读
  • 在macOS环境下使用Electron Builder进行应用打包时遇到签名验证失败的问题,具体表现为签名后spctl命令检测到应用程序未通过公证(Notarization)。本文将详细探讨该问题的原因及解决方案。 ... [详细]
  • 深入理解OAuth认证机制
    本文介绍了OAuth认证协议的核心概念及其工作原理。OAuth是一种开放标准,旨在为第三方应用提供安全的用户资源访问授权,同时确保用户的账户信息(如用户名和密码)不会暴露给第三方。 ... [详细]
  • 本文详细记录了在基于Debian的Deepin 20操作系统上安装MySQL 5.7的具体步骤,包括软件包的选择、依赖项的处理及远程访问权限的配置。 ... [详细]
  • Windows服务与数据库交互问题解析
    本文探讨了在Windows 10(64位)环境下开发的Windows服务,旨在定期向本地MS SQL Server (v.11)插入记录。尽管服务已成功安装并运行,但记录并未正确插入。我们将详细分析可能的原因及解决方案。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • Explore how Matterverse is redefining the metaverse experience, creating immersive and meaningful virtual environments that foster genuine connections and economic opportunities. ... [详细]
  • 优化ASM字节码操作:简化类转换与移除冗余指令
    本文探讨如何利用ASM框架进行字节码操作,以优化现有类的转换过程,简化复杂的转换逻辑,并移除不必要的加0操作。通过这些技术手段,可以显著提升代码性能和可维护性。 ... [详细]
  • Explore a common issue encountered when implementing an OAuth 1.0a API, specifically the inability to encode null objects and how to resolve it. ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • c# – UWP:BrightnessOverride StartOverride逻辑 ... [详细]
  • 数据库内核开发入门 | 搭建研发环境的初步指南
    本课程将带你从零开始,逐步掌握数据库内核开发的基础知识和实践技能,重点介绍如何搭建OceanBase的开发环境。 ... [详细]
  • 本文详细介绍了如何使用 Yii2 的 GridView 组件在列表页面实现数据的直接编辑功能。通过具体的代码示例和步骤,帮助开发者快速掌握这一实用技巧。 ... [详细]
  • 本文深入探讨 MyBatis 中动态 SQL 的使用方法,包括 if/where、trim 自定义字符串截取规则、choose 分支选择、封装查询和修改条件的 where/set 标签、批量处理的 foreach 标签以及内置参数和 bind 的用法。 ... [详细]
  • 本文详细介绍了Java中org.eclipse.ui.forms.widgets.ExpandableComposite类的addExpansionListener()方法,并提供了多个实际代码示例,帮助开发者更好地理解和使用该方法。这些示例来源于多个知名开源项目,具有很高的参考价值。 ... [详细]
author-avatar
孟倩-951127
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有