| DISPLAY[(rep)]  [options]
                                           {[/ ]
                                           [ output-format]output-element}  | 
This document covers the following topics:
For an explanation of the symbols used in the syntax diagram, see Syntax Symbols.
Related Statements: AT END OF
                                PAGE | AT TOP OF
                                PAGE | CLOSE
                                PRINTER | DEFINE PRINTER
                          EJECT |
                          FORMAT |
                          NEWPAGE |
                          PRINT |
                          SKIP |
                          SUSPEND IDENTICAL SUPPRESS
                          | WRITE |
                          WRITE TITLE |
                          WRITE TRAILER 
               
Belongs to Function Group: Creation of Output Reports
The DISPLAY statement is used to specify the fields to
                            be output on a report in column format. A column is created for each field and
                            a field header is placed over the column.
               
See also the following topics (in the Programming Guide):
| Syntax Element | Description | 
|---|---|
| (rep) | Report Specification:  The notation
                                                      As report identification, a value in the range 0 - 31 or a
                                                  logical name which has been assigned using the  If  If this printer file is defined to Natural as PC, the report will be downloaded to the PC, see Example 8. For information on how to control the format of an output report created with Natural, see Report Format and Control in the Programming Guide. | 
| options | Display Options:  For details, see Display Options below. | 
| output-format | Output Format Definitions:  For details, see Output Format Definitions below. | 
| / | Line Advance - Slash
                                                     Notation: When specified within a text element, a slash (/) causes a line advance for the text displayed. When specified between output elements, it causes the output element specified by the slash (/) to be placed vertically within the same column. The header for this column will be constructed by placing the headers of the vertically displayed elements vertically above the column. See also the following topics in the Programming Guide: | 
| output-element |  Output Element: For details, see Output Element below. | 
| [ NOTITLE]
                                               [NOHDR] | 
 | [ AND]
                                               [GIVE] [SYSTEM]FUNCTIONS | 
 | [( statement-parameters)] | 
Syntax Element Description:
| Syntax Element | Description | 
|---|---|
| NOTITLE |  Default Page Title Suppression:
                                                        By default, Natural generates a single title line for
                                                    each page resulting from a  Examples: 
 Note: | 
| NOHDR |  Column Headers:  Column headers are produced for each field specified in
                                                    the  
 Column Header Suppression: To suppress the column header for a single field 
  To suppress all column
                                                       headers 
 Notes: 
 | 
| GIVE SYSTEM
                                                  FUNCTIONS |  Natural System Function Usage:
                                                        The  These functions may then be referred to in a statement executed as a result of an end-of-page condition. Notes: 
 See also Example 2 - DISPLAY Statement Using GIVE SYSTEM FUNCTIONS Clause. | 
| statement-parameters |  Parameter Definition at Statement Level:
                                                        One or more parameters, enclosed within parentheses, may
                                                    be specified at statement level, that is, immediately after the
                                                     Each parameter specified will override the corresponding
                                                    parameter previously specified in a
                                                     If more than one parameter is specified, they must be separated by one or more blanks from one another. Each parameter specification must not be split between two statement lines. Note: See also: | 
The following parameters can be specified with the
                              DISPLAY statement 
               
| Parameter Name | Explanation | Specification possible at statement level (S), at element level (E) or both (SE) | 
|---|---|---|
| AD | Attribute Definition | SE | 
| AL | Alphanumeric Length for Output | SE | 
| CD | Color Definition | SE | 
| CV | Control Variable | SE | 
| DF | Date Format | SE | 
| DL | Display Length for Output | SE | 
| DY | Dynamic Attributes | SE | 
| EM | Edit Mask | SE | 
| EMU | Unicode Edit Mask | E | 
| ES | Empty Line Suppression | S | 
| FC | Filler Character | SE | 
| FL | Floating Point Mantissa Length | SE | 
| GC | Filler Character for Group Headers | SE | 
| HC | Header Centering | SE | 
| HW | Heading Width | SE | 
| IC | Insertion Character | SE | 
| ICU | Unicode Insertion Character | SE | 
| IS | Identical Suppress | SE | 
| LC | Leading Characters | SE | 
| LCU | Unicode Leading Characters | SE | 
| LS | Line Size | S | 
| MC | Multiple-Value Field Count | S | 
| MP | Maximum Number of Pages of a Report | S | 
| NL | Numeric Length for Output | SE | 
| PC | Periodic Group Count | S | 
| PM | Print Mode | SE | 
| PS | Page Size | S | 
| SF | Spacing Factor | SE | 
| SG | Sign Position | SE | 
| TC | Trailing Characters | SE | 
| TCU | Unicode Trailing Characters | SE | 
| UC | Underlining Character | SE | 
| ZP | Zero Printing | SE | 
The individual parameters are described in the Parameter Reference (session parameters).
See also the following topics in the Programming Guide:
DEFINE DATA LOCAL 1 VARI (A4) INIT <'1234'> /* Output END-DEFINE /* Produced * /* --------- DISPLAY NOHDR 'Text' '=' VARI /* Text 1234 DISPLAY NOHDR (AD=U) 'Text' '=' VARI /* Text 1234 DISPLAY NOHDR 'Text' (AD=U) '=' VARI (AD=U)/* Text 1234 DISPLAY NOHDR 'Text' (AD=U) '=' VARI /* Text 1234 END
| 
 | n X | 
 | |||||||||||
| n T | |||||||||||||
| x/y | 
 | 
 | 'text' | 
 | [( attributes)] | 
 | |||||||
| T*field-name | 'c'( n) | 
 | |||||||||||
| P*field-name | |||||||||||||
| 
 | VERTICALLY  | 
 | AS | 
 | ' text'
                                                  
                                                  [(attributes)]
                                                   [CAPTIONED] | 
 | 
 | [/  ] | 
 | ||||
| [ CAPTIONED] | |||||||||||||
| [ HORIZONTALLY] | |||||||||||||
| Syntax Element | Description | 
|---|---|
| nX |  Column Spacing:  This notation inserts
                                                     Example: DISPLAY NAME 5X SALARY See also: 
 | 
| nT |  Tab Setting:  The  In the following example,  DISPLAY 25T NAME 50T SALARY See also: 
 | 
| x/y |  x/y Positioning: The  | 
| 
                                                  T*field-name |  Field Related Positioning:
                                                        The  | 
| 
                                                  P*field-name |  Field and Line Related Positioning:
                                                        The  See also: 
 | 
| Syntax Element | Description | 
|---|---|
| 
                                                  'text'
 |  Text Assignment:  If placed immediately before a field, the text enclosed by single quotes overrides the column heading. The slash character  DISPLAY 'EMPLOYEE' NAME 'MARITAL/STATUS' MAR-STAT If multiple
                                                     See also: 
 | 
| 'c'(n) |  Character Repetition:  The character enclosed by single quotes is displayed
                                                     DISPLAY '*' (5) '=' NAME results in ***** SMITH See also: 
 | 
attributes indicates the output attributes to be used for text display. Attributes can be:
| 
 |     | |
| 
 |  
                                    ad-value |     | 
Where:
ad-value,
                   cd-value and
                   pm-value denote the possible values of
                   the corresponding session parameters AD, CD and
                   PM described
                   in the relevant sections of the Parameter Reference
                   documentation.
               
The compiler actually accepts more than one attribute value for an output
                   field. For example, you can specify: AD=BDI. In such a case,
                   however, only the last value applies. In the given example, only the value
                   I becomes effective and the output field is displayed
                   intensified.
               
For an alphanumeric/Unicode constant (Natural data format A or U), you can
                   specify ad-value and/or
                   cd-value without preceding
                   CD= or AD=, respectively. The single value entered is
                   then checked against all possible CD values first. For
                   example: a value of IRE will be interpreted as intensifed/red but
                   not as intensified/right-justified/mandatory. You cannot combine a single
                   cd-value or
                   ad-value with a value preceded by
                   CD= or AD=.
               
The VERT clause may be used to cause multiple field
                              values to be positioned underneath one another in the same column. In vertical
                              mode, a new column may be initiated by specifying the keyword VERT
                              or HORIZ.
               
The column heading in vertical mode is controlled using the entry
                              or entries specified with the AS clause as described below.
               
| Syntax Element | Description | 
|---|---|
| VERTICALLY | DISPLAY VERT without AS
                                                       Clause:Vertical column orientation. No column heading is
                                               produced if the ASclause is omitted.DISPLAY VERT NAME SALARY For an example, see DISPLAY VERT without AS Clause in the Programming Guide. | 
| AS
                                                  'text' | DISPLAY VERT AS
                                                       'text' Clause:Vertical column
                                               orientation. If AS 'text'is specified,
                                               the text enclosed by single quotes is used as the column heading.For an example, see DISPLAY VERT AS 'text' in the Programming Guide.  The slash character / in the character string of
                                                     DISPLAY VERT AS 'LAST/NAME' NAME | 
| AS
                                                  'text' CAPTIONED | DISPLAY VERT AS
                                                       'text' CAPTIONED Clause:Vertical
                                               column orientation. If AS 'text'
                                                  CAPTIONEDis specified,'text'is used as the column heading and the standard heading text or field name is
                                               inserted immediately before the field value in each detail display line.DISPLAY VERT AS 'PERSONS/SELECTED' CAPTIONED NAME FIRST-NAME For an example, see DISPLAY VERT AS 'text' CAPTIONED in the Programming Guide. | 
| AS CAPTIONED | DISPLAY VERT AS CAPTIONED
                                                       Clause:Vertical column orientation. If AS
                                                  CAPTIONEDis specified, the standard heading text for the field (either
                                               heading text or the field name) will be used as the column heading.DISPLAY VERT AS CAPTIONED NAME FIRST-NAME | 
| HORIZONTALLY | DISPLAY HORIZ
                                                       Clause:Horizontal column orientation. This is the default
                                               display mode. | 
Vertical and horizontal column orientation may be intermixed by using the respective keyword.
To suspend vertical display for a single output element, you may place a dash (-) in front of the element. For example:
DISPLAY VERT NAME - FIRST-NAME SALARY
In the above example, FIRST-NAME will be output
                              horizontally next to NAME, while SALARY will be
                              output vertically again, i.e. below NAME.
               
The standard display mode is horizontal. A column is constructed for each field to be displayed.
Column headings are obtained and used by Natural according to the following priority:
heading 'text'
                                        supplied in the DISPLAY statement;
                     
the default heading defined in the DDM (database fields), or the name of a user-defined variable;
the field name as defined in the DDM (if no heading text was defined for the database field).
For group names, a group heading is produced for the entire group. When specifying a group, only the heading for the entire group may be overridden by a user-specified heading.
The maximum number of column header lines is 15.
Line size overflow is not permitted for output resulting from a
                              DISPLAY statement. If a line overflow occurs, an error message is
                              issued.
               
For more information about vertical/horizontal display usage, see:
Example 6 - DISPLAY Statement Using Vertical and Horizontal Display
DISPLAY VERT AS CAPTIONED and HORIZ (in the Programming Guide)
| 
 | 
 | ' text'
                                                   
                                                  [(attributes)] |     | 
 | |
| ' c'(n)
                                                  [(attributes)] | |||||
| nX | [ '='] {operand1[(parameters)]} | ||||
| nT | |||||
|  x/y  | 
Operand Definition Table:
| Operand | Possible Structure | Possible Formats | Referencing Permitted | Dynamic Definition | |||||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| operand1 | S | A | G | N | A | N | P | I | F | B | D | T | L | G | O | yes | no | ||
Syntax Element Description
| Syntax Element | Description | 
|---|---|
| nX  |  Column Spacing:  This is the same as under Output Format Definitions (see above). | 
| nT  |  Tab Setting:  This is the same as under Output Format Definitions (see above). | 
| x/y |  x/y Positioning:  This is the same as under Output Format Definitions (see above). | 
| 'text' |  Text Assignment:  This is the same as under Output Format Definitions (see above). | 
| 'c'(n) |  Character Repetition:  This is the same as under Output Format Definitions (see above). | 
| 'text'
                                                  '='
 | If 'text' '='is placed immediately before
                                               the field,textis output immediately
                                               before the field value. This applies analogously with'c' (n) '='.DISPLAY '*****' '=' NAME | 
| attributes |  Output Attributes: This is the same as under Output Attributes (see above). | 
| operand1 | The field to be displayed. | 
| parameters |  Parameter Definition at Element (Field)
                                                       Level:  One or more parameters, enclosed within parentheses, may
                                                    be specified at element (field) level, that is, immediately after
                                                     If more than one parameter is specified, one or more blanks must be placed between each entry. An entry must not be split between two statement lines. See also: | 
The following defaults are applicable for a DISPLAY
                            statement:
               
Report Width
 The width of the report defaults to the value set when Natural
                                      is installed. This default value is normally 132 in batch mode or the line
                                      length of the terminal in TP mode. It may be overridden with the session
                                      parameter LS.
                                      In TP mode, line size (LS) and page size
                                      (PS)
                                      parameters are set by Natural based on the physical characteristics of the
                                      terminal type in use.
                     
Terminal Screen Output
 When the DISPLAY output is displayed on a terminal
                                      (emulation) screen, the output begins in physical Column 2 (because Column 1
                                      must be reserved for possible use as an attribute position on a 3270-type
                                      terminal).
                     
Printout on Paper
 When the DISPLAY output is printed on paper, the
                                      printout begins in the leftmost column (Column 1).
                     
Spacing Factor
 The default spacing factor between elements is one position.
                                      There is a minimum of one space between columns (reserved for terminal
                                      attributes). This default may be overridden with the session parameter
                                      SF.
                     
Field Output
 The length of the field or the field heading, whichever is
                                      greater, determines the column width for the report (unless the
                                      HW
                                      parameter is used). 
                     
If the field is longer than the heading, the heading will be
                                                centered over the column unless the HC=L or
                                                HC=R parameter is
                                                used to produce a left-justified or right-justified heading.
                           
If the heading is longer than the field, the field will be left-justified under the heading.
The values contained in the field are left-justified for alphanumeric fields and right-justified for numeric fields.
Numeric fields may be displayed left-justified by specifying
                                                AD=L.
                           
Alphanumeric fields may be displayed right-justified by
                                                specifying AD=R.
                           
In a vertical display, the longest data value or heading
                                                among all fields determines the column width (unless the
                                                HW
                                                parameter is used).
                           
Sign
 One extra high-order print position is reserved for a sign when
                                      printing a numeric field. The session parameter
                                      SG may be
                                      used to suppress the sign position.
                     
Page Overflow
 Page overflow is checked before execution of a
                                      DISPLAY statement. No new page title or trailer information is
                                      generated during the execution of a DISPLAY statement.
                     
Example 2 - DISPLAY Statement Using GIVE SYSTEM FUNCTIONS Clause
Example 4 - DISPLAY Statement Using 'text ', 'c(n)' and Attribute Notation
Example 6 - DISPLAY Statement Using Vertical and Horizontal Display
Example 7 - DISPLAY Statement Using Parameters on Statement/Element Level
Example 8 - Report Specification with Output File Defined to Natural as PC
** Example 'DISEX1': DISPLAY (with nX, nT notation) ************************************************************************ DEFINE DATA LOCAL 1 EMPL-VIEW VIEW OF EMPLOYEES 2 NAME 2 JOB-TITLE END-DEFINE * LIMIT 4 READ EMPL-VIEW BY NAME DISPLAY NOTITLE 5X NAME 50T JOB-TITLE END-READ * END
        NAME                                         CURRENT         
                                                    POSITION         
--------------------                        -------------------------
                                                                     
ABELLAN                                     MAQUINISTA               
ACHIESON                                    DATA BASE ADMINISTRATOR  
ADAM                                        CHEF DE SERVICE          
ADKINSON                                    PROGRAMMER 
                        
                      
                       
               ** Example 'DISEX2': DISPLAY (with GIVE SYSTEM FUNCTIONS)               
************************************************************************
DEFINE DATA LOCAL                                                       
1 EMPLOY-VIEW VIEW OF EMPLOYEES                                         
  2 PERSONNEL-ID                                                        
  2 NAME                                                                
  2 FIRST-NAME                                                          
  2 SALARY    (1)                                                       
  2 CURR-CODE (1)                                                       
END-DEFINE                                                              
*                                                                       
LIMIT 15                                                                
FORMAT PS=15                                                            
*                                                                       
READ EMPLOY-VIEW                                                        
  DISPLAY GIVE SYSTEM FUNCTIONS                                         
          PERSONNEL-ID NAME FIRST-NAME SALARY (1) CURR-CODE (1)
  AT END OF PAGE                                                        
    WRITE /    'SALARY STATISTICS:'                                     
          / 7X 'MAXIMUM:' MAX(SALARY(1))  CURR-CODE (1)
          / 7X 'MINIMUM:' MIN(SALARY(1))  CURR-CODE (1)
          / 7X 'AVERAGE:' AVER(SALARY(1)) CURR-CODE (1)
  END-ENDPAGE                                          
END-READ                                               
*                                                      
END 
                         Page      1                                                  05-01-12  09:47:48
                                                                               
PERSONNEL         NAME              FIRST-NAME        ANNUAL   CURRENCY        
   ID                                                 SALARY     CODE          
--------- -------------------- -------------------- ---------- --------        
                                                                               
50005500  BLOND                ALEXANDRE                172000 FRA             
50005300  MAIZIERE             ELISABETH                166900 FRA             
50004900  CAOUDAL              ALBERT                   167350 FRA             
50004600  VERDIE               BERNARD                  170100 FRA             
50004200  VAUZELLE             BERNARD                  159790 FRA             
50004100  CHAPUIS              ROBERT                   169900 FRA             
50003800  JOUSSELIN            DANIEL                   171990 FRA             
50006900  BAILLET              PATRICK                  188000 FRA             
50007600  MARX                 JEAN-MARIE               365700 FRA             
                                                                               
SALARY STATISTICS:                                                             
       MAXIMUM:     365700 FRA                                                 
       MINIMUM:     159790 FRA                                                 
       AVERAGE:     192414 FRA 
                        
                      
                       
               ** Example 'DISEX3': DISPLAY (with P* notation)                         
************************************************************************
DEFINE DATA LOCAL                                                       
1 EMPL-VIEW VIEW OF EMPLOYEES                                           
  2 NAME                                                                
  2 SALARY (1)                                                          
  2 BIRTH                                                               
  2 CITY                                                                
END-DEFINE                                                              
*                                                                       
LIMIT 2                                                                 
READ EMPL-VIEW BY CITY FROM 'N'                                         
 DISPLAY NOTITLE NAME CITY                                             
          VERT AS 'BIRTH/SALARY' BIRTH (EM=YYYY-MM-DD) SALARY (1)
  SKIP 1                                                                
  AT BREAK OF CITY                                                          
    DISPLAY P*SALARY (1) AVER(SALARY (1))                         
    SKIP 1                                                              
  END-BREAK                                                             
END-READ
END 
                                 NAME                 CITY           BIRTH   
                                            SALARY  
-------------------- -------------------- ----------
                                                    
WILCOX               NASHVILLE            1970-01-01
                                               38000
                                                    
MORRISON             NASHVILLE            1949-07-10
                                               36000
                                                    
                                                    
                                               37000 
                        
                      
                       
               ** Example 'DISEX4': DISPLAY (with 'c(n)' notation and attribute)       
************************************************************************
DEFINE DATA LOCAL                                                       
1 EMPL-VIEW VIEW OF EMPLOYEES                                           
  2 DEPT                                                                
  2 LEAVE-DUE                                                           
  2 NAME                                                                
END-DEFINE                                                              
*                                                                       
LIMIT 4                                                                 
READ EMPL-VIEW BY DEPT FROM 'T'                                         
  IF LEAVE-DUE GT 40                                                    
   DISPLAY NOTITLE                                                     
           'EMPLOYEE' NAME                /* OVERRIDE STANDARD HEADER   
           'LEAVE ACCUMULATED' LEAVE-DUE  /* OVERRIDE STANDARD HEADER   
           '*'(10)(I)                     /* DISPLAY 10 '*' INTENSIFIED 
  ELSE                                                                  
    DISPLAY NAME LEAVE-DUE                                         
  END-IF                                                                
END-READ
*       
END 
                               EMPLOYEE       LEAVE ACCUMULATED           
-------------------- -----------------           
                                                 
LAVENDA               33                         
BOYER                 33                         
CORREARD              45               **********
BOUVIER               19 
                        
                       
               ** Example 'DISEX5': DISPLAY (horizontal display) ************************************************************************ DEFINE DATA LOCAL 1 EMPL-VIEW VIEW OF EMPLOYEES 2 NAME 2 JOB-TITLE 2 SALARY (1:2) 2 CURR-CODE (1:2) END-DEFINE * LIMIT 4 READ EMPL-VIEW BY NAME DISPLAY NOTITLE NAME JOB-TITLE SALARY (1:2) CURR-CODE (1:2) SKIP 1 END-READ * END
        NAME                  CURRENT            ANNUAL   CURRENCY
                             POSITION            SALARY     CODE  
-------------------- ------------------------- ---------- --------
                                                                  
ABELLAN              MAQUINISTA                   1450000 PTA     
                                                  1392000 PTA     
                                                                  
ACHIESON             DATA BASE ADMINISTRATOR        11300 UKL     
                                                    10500 UKL     
                                                                  
ADAM                 CHEF DE SERVICE               159980 FRA     
                                                        0         
                                                                  
ADKINSON             PROGRAMMER                     34500 USD     
                                                    31700 USD 
                        
                      
                       
               ** Example 'DISEX6': DISPLAY (vertical and horizontal display)          
************************************************************************
DEFINE DATA LOCAL                                                       
1 EMPL-VIEW VIEW OF EMPLOYEES                                           
  2 NAME                                                                
  2 CITY                                                                
  2 JOB-TITLE                                                           
  2 SALARY    (1:2)                                                     
  2 CURR-CODE (1:2)                                                     
END-DEFINE                                                              
*                                                                       
LIMIT 1                                                                 
READ EMPL-VIEW BY NAME                                                  
 DISPLAY NOTITLE VERT AS CAPTIONED                                     
          NAME CITY 'POSITION' JOB-TITLE                                
          HORIZ 'SALARY' SALARY (1:2) 'CURRENCY' CURR-CODE (1:2)
  /*                                                                    
  SKIP 1                                                                
END-READ 
END 
                                   NAME              SALARY   CURRENCY
          CITY                               
        POSITION                             
------------------------- ---------- --------
                                             
ABELLAN                      1450000 PTA     
MADRID                       1392000 PTA     
MAQUINISTA 
                        
                      
                       
               ** Example 'DISEX7': DISPLAY (with parameters for statement/element)    
************************************************************************
DEFINE DATA LOCAL                                                       
1 EMPL-VIEW VIEW OF EMPLOYEES                                           
  2 NAME                                                                
  2 PERSONNEL-ID                                                        
  2 TELEPHONE                                                           
    3 AREA-CODE                                                         
    3 PHONE                                                             
END-DEFINE                                                              
*                                                                       
LIMIT 3                                                                 
READ EMPL-VIEW BY NAME                                                  
 DISPLAY NOTITLE (AL=16 GC=+ NL=8 SF=3 UC==)                           
          PERSONNEL-ID NAME TELEPHONE (LC=< TC=>)                 
END-READ                                                                
END 
                            PERSONNEL             NAME         +++++++++++++++TELEPHONE+++++++++++++++
       ID                                                                    
                                             AREA              TELEPHONE     
                                             CODE                            
================   ================   ==================   ==================
                                                                             
60008339           ABELLAN            <1     >             <4356726        > 
30000231           ACHIESON           <0332  >             <523341         > 
50005800           ADAM               <1033  >             <44864858       > 
                        
                      
                       
               ** Example 'PCDIEX1': DISPLAY and WRITE to PC                           
**                                                                      
** NOTE: Example requires that Natural Connection is installed.         
************************************************************************
DEFINE DATA LOCAL                                                       
01 PERS VIEW OF EMPLOYEES                                               
  02 PERSONNEL-ID                                                       
  02 NAME                                                               
  02 CITY                                                               
END-DEFINE                                                              
*                                                                       
FIND PERS WITH CITY = 'NEW YORK'               /* Data selection        
  WRITE (7) TITLE LEFT 'List of employees in New York' /                
  DISPLAY (7)          /* (7) designates the output file (here the PC).
    'Location'  CITY                                                    
    'Surname'   NAME                                                    
    'ID'        PERSONNEL-ID                                            
END-FIND                                                                
END