Documentation Comments
Use this form to comment on this topic. You can also provide any general observations about the Online Documentation, or request that additional information be added in a future release.
Reality V15.2 Online Documentation (MoTW) Revision 3
READ Statement (DataBasic) (m618703+read_s.htm)
Reads a file item and assigns its value, as a dynamic array, to a variable.
READ dyn-array FROM {file-var,}item-id {SETTING setting-var} {LOCKED statement(s)} [THEN statement(s) | ELSE statement(s)]
dyn-array The name of the variable into which the elements of the file item are assigned as a dynamic array.
file-var The name of a variable containing a file reference (assigned via an OPEN statement). If file-var is not specified, the internal default file variable is used; that is, the file used is that most recently opened without a file variable.
item-id The name of the item from which the data is to be read.
setting-var The name of a variable 
that is set to a return value. If the data is read successfully, 
If the item is locked, 
statement(s) A sequence of one or more valid DataBasic statements, either separated by semicolons or contained on separate lines and followed by an END statement.
The LOCKED clause (if any) is executed if the item is locked by another process. Use SYSTEM(43) to obtain the number of the port that has locked the item.
If a LOCKED clause is present, the statement sets a lock on the item (that is, it functions like READU).
A THEN or an ELSE clause, or both, must be included.
Note: This behaviour can be changed with the NO.IO.ERR compatibility option.
If the specified file has not been opened prior to the READ statement, the program aborts with an error message.
READU statement, READV statement, READVU statement.
READ X1 FROM W,"TEMP" ELSE PRINT "NON-EXISTENT"; STOP
Reads the item named TEMP from the file opened and assigned to file variable W and assigns its string value to variable X1. If TEMP does not exist, the message NON-EXISTENT is displayed and the program is terminated.
A="TEST" B="1" READ X FROM C,(A CAT B) ELSE STOP
Reads item TEST1 from file opened and assigned to file variable C and assigns its value to variable X. Program terminates if TEST1 does not exist.
READ Z FROM "Q1" THEN PRINT X; STOP
Reads item Q1 from the file opened without a file variable and assigns its value to variable Z. Prints value of X and terminates program if Q1 does not exist.