2024年PHP开发者大会日本站

odbc_procedurecolumns

(PHP 4, PHP 5, PHP 7, PHP 8)

odbc_procedurecolumns检索关于过程参数的信息

描述

odbc_procedurecolumns(
    Odbc\Connection $odbc,
    ?string $catalog = null,
    ?string $schema = null,
    ?string $procedure = null,
    ?string $column = null
): Odbc\Result|false

检索关于过程参数的信息。

参数

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_CATPROCEDURE_SCHEMPROCEDURE_NAMECOLUMN_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
)

参见

添加注释

用户贡献的注释

此页面没有用户贡献的注释。
To Top