Page 429
The Syntax for the IS_OPEN Function
The format for the function IS_OPEN is
FUNCTION IS_OPEN(file_handle IN UTL_FILE.FILE_TYPE) RETURN BOOLEAN;
If the file is open, the value true is returned; otherwise, false is returned. file_handle is the file handle returned by FOPEN.
Using GET_LINE for File Input
When performing file input, in order to read data from the file into the buffer, you'll use
the GET_LINE function. The maximum input length is 1022 bytes.
NOTE |
When the line is read into the buffer, the function does not pass the newline character (\n for all you C programmers out there). If you are reading in a fixed-length record where the data is 60 characters, you will not have to worry about the carriage return/line feed characters. Your buffer in this case would have to be only 60 characters. If you do need to add a newline character, you can use the NEW_LINE procedure as discussed later in the chapter in the section "File Output." |
The Syntax for the GET_LINE Function
The format for the function GET_LINE is
PROCEDURE GET_LINE(file_handle IN UTL_FILE.FILE_TYPE, buffer OUT VARCHAR2);
The first parameter, file_handle, is the file handle returned from the FOPEN function. The second parameter, buffer, is the buffer of type VARCHAR2. Possible errors that could arise are shown in Table 18.2.
Table 18.2. Exceptions raised by GET_LINE.
Error Raised | Description of Error |
UTL_FILE.INVALID_FILEHANDLE | Not a valid file handle. |
UTL_FILE.INVALID_OPERATION | File not opened for reading (`R' mode), or problems with file permissions. |
UTL_FILE.VALUE_ERROR | Buffer not long enough to hold input from file up to the newline character. |
UTL_FILE.NO_DATA_FOUND | End of file has been reached. |
continues
Page 430
Table 18.2. continued
Error Raised | Description of Error |
UTL_FILE.INTERNAL_ERROR | Error internal to the system. |
UTL_FILE.READ_ERROR | Operating system error occurred while reading from the file. |
Because you can input files, you should be able to output files. As you will see, this is a great method for importing and exporting files from one application, operating system, and so on to another. It works well in mixed IBM, UNIX, and PC shops. The steps to output to a file are as follows:
The next few sections look at the detailed process of writing to a file into Oracle.
Opening a File for Output
You will open the file in the same manner for output as you did for input. The only
difference is that the mode of operations will be
REPLACE (`W') or APPEND (`A').
The Syntax for Opening a File for Output
The syntax again is
FUNCTION FOPEN(location IN VARCHAR2, filename IN VARCHAR2, openmode IN VARCHAR2) RETURN UTL_FILE.FILE_TYPE;
All the same exceptions apply to opening the file for writing as they did for reading
from a file.
Page 431
TIP |
If you are experiencing user data exceptions when calling this function, there are two possibilities. One is that the Oracle product has been corrupted and needs to be reinstalled. The second is a possible problem in Windows NT or UNIX, where the filename specified also has to include the path. Try both of these if you get an error message with SYS:UTL_FILE on lines 82 and 120. |
Using IS_OPEN to Test If a File Is Open When Writing
to a File
You should test to make sure the file is open before writing to the file. This can
be accomplished through properly handling the raised exceptions.
The Syntax for Testing to Make Sure a File Is Open
The syntax is still the same for both reading and writing to files:
FUNCTION IS_OPEN(file_handle IN UTL_FILE.FILE_TYPE) RETURN BOOLEAN;
If the file is open, the value true is returned; otherwise, false is returned. file_handle is the file handle returned by FOPEN.
Using PUT to Write to the Output File
The PUT procedure outputs the string to the output file. This assumes that the file has
been opened for writing.
The Syntax for the PUT Procedure
The format for the PUT procedure is
PROCEDURE PUT(file_handle IN UTL_FILE.FILE_TYPE, buffer IN VARCHAR2);
The file_handle parameter is the file handle returned from FOPEN. The buffer parameter is the output to the file. The maximum length of the buffer is 1023. Table 18.3 lists possible exceptions and their meanings.
Table 18.3. Exceptions raised by PUT, PUT_LINE, PUTF, and FFLUSH.
Error Raised | Description of Error |
UTL_FILE.INVALID_FILEHANDLE | Not a valid file handle |
UTL_FILE.INVALID_OPERATION | Attempting to write to a file without the proper permissions or not specifying `W' or `A' for output mode |
UTL_FILE.WRITE_ERROR | Error caused by the operating system when attempting to write to a file, such as disk full error |
UTL_FILE.INTERNAL_ERROR | Error internal to the system |
Page 432
NOTE |
Similar to the GET_LINE procedure, PUT does not output a newline character. You can use the NEW_LINE procedure to write out the newline character for your specific operating system, which is discussed in the following section. |
Using the NEW_LINE Procedure
The NEW_LINE procedure outputs one or more newline characters in the format specified
by the operating system. For instance, ASCII is
`0D0A' and EBCDIC is `0D25' for the newline character. This procedure would be used to add a newline character in conjunction with
the PUT statement.
The Syntax for the NEW_LINE Procedure
PROCEDURE NEW_LINE(file_handle IN UTL_FILE.FILE_TYPE, no_newline_output IN NATURAL :=1);
The file_handle parameter is the file handle returned from FOPEN. no_newline_output is the total number of newline characters you want to write to the file. The default is one newline character if not specified. The same exceptions are raised as with PUT, so you can refer to Table 18.3 for a brief review.
TIP |
To simplify writing output to a file, which requires a newline character, you could easily create a function called WRITE_LINE, which will then output using PUT, and then call the NEW_LINE procedure. This works great for features such as double spacing. The other trick is to simply use PUT_LINE (if only one newline character per line) or PUTF (most flexible, combination of PUT, PUT_LINE, NEW_LINE and then some), which supports the NEW_LINE procedure. |
Using the PUT_LINE Procedure
The PUT_LINE procedure outputs a string to a file, followed by the platform-specific
newline character. Basically it combines PUT and
NEW_LINE into one procedure. Again, it is assumed that the file has been opened before you attempt to write to the file.
The Syntax for the PUT_LINE Procedure
PROCEDURE PUT_LINE(file_handle IN UTL_FILE.FILE_TYPE, buffer IN VARCHAR2);
The file_handle parameter is the file handle returned from FOPEN. buffer is your output string, which will be terminated by the newline character associated with the operating system. The same exceptions are raised as with PUT, so you can refer to Table 18.3 for a brief review.