Field value pairs (File architecture): Difference between revisions
mNo edit summary |
mNo edit summary |
||
Line 1: | Line 1: | ||
== Overview == | ==Overview== | ||
<p>The basic unit of storage inside a Model 204 record is the field value pair (or, more literally, "field = value pair"). A record or a field group contains a series of field groups and field value pairs.</p> | |||
A record can contain multiple field value pairs for fields with the [[Field design (File management)#OCCURS_attribute|OCCURS attribute]]. | |||
A record or a field group can contain non-<var>OCCURS</var> field value pairs, whose physical structure is described below, for each storage data type. | |||
A record or a | |||
==STRING fields== | |||
<p>The field value pair for <var>STRING</var> fields contains three parts: </p> | <p>The field value pair for <var>STRING</var> fields contains three parts: </p> | ||
<ul> | |||
<li>The field code from [[Table A (File architecture)|Table A]]: 3 bytes for <var>[[FILEORG parameter|FILEORG]]</var> X'100' files, or 2 bytes for all others. </li> | |||
<li>The length of the value for this pair (0 to 255): 1 byte.</li> | |||
< | <li>The value: variable length, 0-255 bytes.</li> | ||
</ul> | |||
<p>For example, a NAME field containing 'SMITH' is held in either 8 or 9 bytes (depending on the FILEORG), while a NAME of 'FRANKENSTEIN' is held in either 15 or 16 bytes.</p> | |||
<p> | ==BINARY or CODED fields== | ||
<p> | |||
The storage of <var>[[Field design (File management)#BINARY attribute|BINARY]]</var> and <var>[[Field design (File management)#CODED attribute|CODED]]</var> fields depends on whether the file has the Optimized Field Extraction ([[FILEORG parameter|FILEORG]] x'80') bit set. Note that [[FILEORG parameter|FILEORG]] X'100' files automatically also turn on x'80'. </p> | |||
<p>For files that are <i>not</i> Optimized Field Extraction Files (x'80), the field value pair contains two parts:</p> | |||
<ul> | |||
<li>The field code from [[Table A (File architecture)|Table A]]: 2 bytes. | |||
<li>The value: '''always''' held as 4 bytes. | |||
</ul> | |||
<p> | <p>For Optimized Field Extraction Files, the field value pair contains three parts:</p> | ||
<ul> | |||
<li>The field code from [[Table A (File architecture)|Table A]]: 3 bytes for [[FILEORG parameter|FILEORG]] X'100' files, or 2 bytes for all others. | |||
<li>The length of the value for this pair (1 to 4): 1 byte. | |||
<p>< | <li>The value: variable length, 1-4 bytes. | ||
</ul> | |||
<p> | |||
By storing a length with <b>all</b> field occurrences, data in records can be read much faster. The possible trade-off on performance versus space is discussed in [[File design (File management)#X'80' - Optimized Field Extraction files|X'80' - Optimized Field Extraction files]]. </p> | |||
<p> | ==FLOAT fields== | ||
<p> | |||
The storage of <var>[[Field design (File management)#FLOAT attribute|FLOAT]]</var> fields depends on whether the file has the Optimized Field Extraction (<var>[[FILEORG parameter|FILEORG]]</var> x'80') bit set. | |||
<p class="note"><b>Note:</b> <var>FILEORG</var> X'100' files automatically also turn on x'80'. </p> | |||
<p>For files that are <i>not</i> Optimized Field Extraction files, the field value pair contains two parts:</p> | |||
<ul> | |||
<li>The field code from [[Table A (File architecture)|Table A]]: 2 bytes. | |||
<li>The value: '''always''' held as 4, 8, or 16 bytes, depending on the <var>LENGTH</var> attribute. | |||
</ul> | |||
<p>For Optimized Field Extraction | <p>For Optimized Field Extraction files, the field value pair contains three parts:</p> | ||
<ul> | |||
<li>The field code from Table A: 3 bytes for <var>FILEORG</var> X'100' files, or 2 bytes for all others. | |||
<li>The length of the value for this pair (1 to 4): 1 byte. | |||
<p>By storing a length with <b>all</b> field occurrences, data in records can be read much faster. The possible | <li>The value: '''always''' held as 4, 8, or 16 bytes, depending on the <var>LENGTH</var> attribute. | ||
</ul> | |||
<p> | |||
By storing a length with <b>all</b> field occurrences, data in records can be read much faster. The possible trade-off on performance versus space is discussed in [[File design (File management)#X'80' - Optimized Field Extraction files|X'80' - Optimized Field Extraction files]].</p> | |||
[[Category:File architecture]] | [[Category:File architecture]] |
Revision as of 00:23, 23 January 2014
Overview
The basic unit of storage inside a Model 204 record is the field value pair (or, more literally, "field = value pair"). A record or a field group contains a series of field groups and field value pairs.
A record can contain multiple field value pairs for fields with the OCCURS attribute.
A record or a field group can contain non-OCCURS field value pairs, whose physical structure is described below, for each storage data type.
STRING fields
The field value pair for STRING fields contains three parts:
- The field code from Table A: 3 bytes for FILEORG X'100' files, or 2 bytes for all others.
- The length of the value for this pair (0 to 255): 1 byte.
- The value: variable length, 0-255 bytes.
For example, a NAME field containing 'SMITH' is held in either 8 or 9 bytes (depending on the FILEORG), while a NAME of 'FRANKENSTEIN' is held in either 15 or 16 bytes.
BINARY or CODED fields
The storage of BINARY and CODED fields depends on whether the file has the Optimized Field Extraction (FILEORG x'80') bit set. Note that FILEORG X'100' files automatically also turn on x'80'.
For files that are not Optimized Field Extraction Files (x'80), the field value pair contains two parts:
- The field code from Table A: 2 bytes.
- The value: always held as 4 bytes.
For Optimized Field Extraction Files, the field value pair contains three parts:
- The field code from Table A: 3 bytes for FILEORG X'100' files, or 2 bytes for all others.
- The length of the value for this pair (1 to 4): 1 byte.
- The value: variable length, 1-4 bytes.
By storing a length with all field occurrences, data in records can be read much faster. The possible trade-off on performance versus space is discussed in X'80' - Optimized Field Extraction files.
FLOAT fields
The storage of FLOAT fields depends on whether the file has the Optimized Field Extraction (FILEORG x'80') bit set.
Note: FILEORG X'100' files automatically also turn on x'80'.
For files that are not Optimized Field Extraction files, the field value pair contains two parts:
- The field code from Table A: 2 bytes.
- The value: always held as 4, 8, or 16 bytes, depending on the LENGTH attribute.
For Optimized Field Extraction files, the field value pair contains three parts:
- The field code from Table A: 3 bytes for FILEORG X'100' files, or 2 bytes for all others.
- The length of the value for this pair (1 to 4): 1 byte.
- The value: always held as 4, 8, or 16 bytes, depending on the LENGTH attribute.
By storing a length with all field occurrences, data in records can be read much faster. The possible trade-off on performance versus space is discussed in X'80' - Optimized Field Extraction files.