(PHP 4, PHP 5, PHP 7, PHP 8)
odbc_procedurecolumns — 检索关于过程参数的信息
$odbc
,$catalog
= null
,$schema
= null
,$procedure
= null
,$column
= null
检索关于过程参数的信息。
odbc
ODBC连接对象,详情请参见odbc_connect()。
catalog
目录(ODBC 2 中称为“限定符”)。
schema
模式(ODBC 2 中称为“所有者”)。此参数接受以下搜索模式:%
匹配零个或多个字符,_
匹配单个字符。
procedure
过程。此参数接受以下搜索模式:%
匹配零个或多个字符,_
匹配单个字符。
column
列。此参数接受以下搜索模式:%
匹配零个或多个字符,_
匹配单个字符。
返回输入和输出参数列表,以及构成指定过程结果集的列。失败时返回 ODBC 结果对象或false
。
结果集包含以下列
PROCEDURE_CAT
PROCEDURE_SCHEM
PROCEDURE_NAME
COLUMN_NAME
COLUMN_TYPE
DATA_TYPE
TYPE_NAME
COLUMN_SIZE
BUFFER_LENGTH
DECIMAL_DIGITS
NUM_PREC_RADIX
NULLABLE
REMARKS
COLUMN_DEF
SQL_DATA_TYPE
SQL_DATETIME_SUB
CHAR_OCTET_LENGTH
ORDINAL_POSITION
IS_NULLABLE
结果集按PROCEDURE_CAT
、PROCEDURE_SCHEM
、PROCEDURE_NAME
和COLUMN_TYPE
排序。
版本 | 描述 |
---|---|
8.4.0 |
odbc 现在期望一个Odbc\Connection实例;以前,期望的是一个resource。 |
8.4.0 | 此函数现在返回一个Odbc\Result实例;以前,返回的是一个resource。 |
8.0.0 | 在此版本之前,此函数只能使用一个或五个参数调用。 |
示例 #1 列出存储过程的列
<?php
$conn = odbc_connect($dsn, $user, $pass);
$columns = odbc_procedurecolumns($conn, 'TutorialDB', 'dbo', 'GetEmployeeSalesYTD;1', '%');
while (($row = odbc_fetch_array($columns))) {
print_r($row);
break; // 为简洁起见,省略了后续行
}
?>
以上示例将输出类似于以下内容
Array ( [PROCEDURE_CAT] => TutorialDB [PROCEDURE_SCHEM] => dbo [PROCEDURE_NAME] => GetEmployeeSalesYTD;1 [COLUMN_NAME] => @SalesPerson [COLUMN_TYPE] => 1 [DATA_TYPE] => -9 [TYPE_NAME] => nvarchar [COLUMN_SIZE] => 50 [BUFFER_LENGTH] => 100 [DECIMAL_DIGITS] => [NUM_PREC_RADIX] => [NULLABLE] => 1 [REMARKS] => [COLUMN_DEF] => [SQL_DATA_TYPE] => -9 [SQL_DATETIME_SUB] => [CHAR_OCTET_LENGTH] => 100 [ORDINAL_POSITION] => 1 [IS_NULLABLE] => YES )