getProcedureColumns(String catalog, String schemaPattern, String procedureNamePattern, String columnNamePattern)
Syntax:
ResultSet getProcedureColumns(String catalog, String schemaPattern, String procedureNamePattern, String columnNamePattern) throws SQLException
Description:
Retrieves a description of the given catalog's stored procedure parameter and result columns.
Only descriptions matching the schema, procedure and parameter name criteria are returned. They are ordered by PROCEDURE_CAT, PROCEDURE_SCHEM, PROCEDURE_NAME and SPECIFIC_NAME. Within this, the return value, if any, is first. Next are the parameter descriptions in call order. The column descriptions follow in column number order.
Each row in the ResultSet is a parameter description or column description with the following fields:
PROCEDURE_CAT | String | procedure catalog (may be null) |
PROCEDURE_SCHEM | String | procedure schema (may be null) |
PROCEDURE_NAME | String | procedure name |
COLUMN_NAME | String | column/parameter name |
COLUMN_TYPE | short | kind of column/parameter:
|
DATA_TYPE | int | SQL type from java.sql.Types |
TYPE_NAME | String | SQL type name, for a UDT type the type name is fully qualified |
PRECISION | int | precision |
LENGTH | int | length in bytes of data |
SCALE | short | scale - null is returned for data types where SCALE is not applicable. |
RADIX | short | radix |
NULLABLE | short | can it contain NULL.
|
REMARKS | String | comment describing parameter/column |
COLUMN_DEF | String | default value for the column, which should be interpreted as a string when the value is enclosed in single quotes (may be null)
|
SQL_DATA_TYPE | int | reserved for future use |
SQL_DATETIME_SUB | int | reserved for future use |
CHAR_OCTET_LENGTH | int | the maximum length of binary and character based columns. For any other datatype the returned value is a NULL |
ORDINAL_POSITION | int | the ordinal position, starting from 1, for the input and output parameters for a procedure. A value of 0 is returned if this row describes the procedure's return value. For result set columns, it is the ordinal position of the column in the result set starting from 1. If there are multiple result sets, the column ordinal positions are implementation defined. |
IS_NULLABLE | String |
ISO rules are used to determine the nullability for a column.
|
SPECIFIC_NAME | String | the name which uniquely identifies this procedure within its schema. |
The PRECISION
column represents the specified column size for the given column. For numeric data, this is the maximum precision. For character data, this is the length in characters. For datetime datatypes, this is the length in characters of the String representation (assuming the maximum allowed precision of the fractional seconds component). For binary data, this is the length in bytes. For the ROWID
datatype, this is the length in bytes. Null is returned for data types where the column size is not applicable.
Parameters:
catalog - a catalog name; must match the catalog name as it is stored in the database; "" retrieves those without a catalog; null means that the catalog name should not be used to narrow the search
schemaPattern - a schema name pattern; must match the schema name as it is stored in the database; "" retrieves those without a schema; null means that the schema name should not be used to narrow the search
procedureNamePattern - a procedure name pattern; must match the procedure name as it is stored in the database
columnNamePattern - a column name pattern; must match the column name as it is stored in the database
Returns:
ResultSet
- each row describes a stored procedure parameter or column
Throws:
SQLException - if a database access error occurs