(PHP 4, PHP 5, PHP 7, PHP 8)
odbc_procedurecolumns — Получает информацию о параметрах процедур
$odbc,$catalog = null,$schema = null,$procedure = null,$column = nullФункция получает информацию о параметрах процедур.
odbcОбъект ODBC-соединения. Подробнее о коннекторе рассказывает описание функции odbc_connect().
catalogКаталог ('qualifier' на языке ODBC 2).
schema
Схема ('owner' на языке ODBC 2).
Параметр принимает следующие шаблоны поиска:
%, который соответствует нулю или более символам,
и _, который соответствует ровно одному символу.
procedure
Процедура.
Параметр принимает следующие шаблоны поиска:
%, который соответствует нулю или более символам,
и _, который соответствует ровно одному символу.
column
Столбец.
Параметр принимает следующие шаблоны поиска:
%, который соответствует нулю или более символам,
и _, который соответствует ровно одному символу.
Функция возвращает список входных и выходных параметров, и столбцы,
из которых состоит набор результатов для заданных процедур.
Функция возвращает объект ODBC с результатом или false, если возникла ошибка.
Набор результатов содержит следующие столбцы:
PROCEDURE_CATPROCEDURE_SCHEMPROCEDURE_NAMECOLUMN_NAMECOLUMN_TYPEDATA_TYPETYPE_NAMECOLUMN_SIZEBUFFER_LENGTHDECIMAL_DIGITSNUM_PREC_RADIXNULLABLEREMARKSCOLUMN_DEFSQL_DATA_TYPESQL_DATETIME_SUBCHAR_OCTET_LENGTHORDINAL_POSITIONIS_NULLABLE
Набор результатов упорядочивается по столбцам PROCEDURE_CAT, PROCEDURE_SCHEM,
PROCEDURE_NAME и COLUMN_TYPE.
| Версия | Описание |
|---|---|
| 8.4.0 |
Параметр odbc теперь ожидает экземпляр соединения Odbc\Connection;
раньше ожидался аргумент с типом resource.
|
| 8.4.0 | Функция теперь возвращает объект с результатом ODBC-запроса 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
)