srv_paramset (API-интерфейс расширенных хранимых процедур)
Область применения: SQL Server
Внимание
Эта функция будет удалена в будущей версии SQL Server. Избегайте использования этого компонента в новых разработках и запланируйте изменение существующих приложений, в которых он применяется. Пользуйтесь вместо этого интеграцией со средой CLR.
Устанавливает значение возвратного параметра вызова удаленной хранимой процедуры. Эта функция заменена функцией srv_paramsetoutput.
Синтаксис
int srv_paramset (
SRV_PROC *
srvproc
,
int
n
,
void *
data
,
int
len
);
Аргументы
srvproc
Указатель на структуру SRV_PROC, представляющую собой дескриптор соединения с клиентом (в данном случае — дескриптор, который получил вызов удаленной хранимой процедуры). Эта структура содержит сведения, которые используются библиотекой API-интерфейса расширенных хранимых процедур для управления связью и передачи данных между приложением и клиентом.
n
Указывает номер параметра, который должен быть задан. Первый параметр имеет значение 1.
data
Указатель на значение данных, которое должно быть отправлено назад клиенту, как возвратный параметр удаленной хранимой процедуры.
len
Указывает фактическую длину данных, которые должны быть возвращены. Если тип данных параметра имеет постоянную длину и не допускает значений NULL (например, srvbit или srvint1), параметр len не учитывается.
Возвраты
SUCCEED, если значение параметра было успешно установлено; в противном случае — FAIL. Значение FAIL возвращается, если удаленной хранимой процедуры сейчас не существует, если у нее нет параметра с номером n, если параметр не является возвращаемым или если аргумент len недопустимый.
Если len имеет значение 0, то возвращается NULL. Единственным способом возвратить значение NULL клиенту является задание параметру len значения 0.
Эта функция возвращает следующие значения, если параметр является одним из типов данных Microsoft SQL Server 2005 (9.x).
Новые типы данных | Длина возвращаемых данных |
---|---|
BITN | NULL: len = 0, данные = IG, RET = 0 ZERO: недоступно >=255: N/A <255: недоступно |
BIGVARCHAR | NULL: len = 0, данные = IG, RET = 1 ZERO: len = IG, data = IG, RET = 0 >=255: len = max8k, data = valid, RET = 0 <255: len = <8k, data = valid, RET = 1 |
BIGCHAR | NULL: len = 0, данные = IG, RET = 1 ZERO: len = IG, data = IG, RET = 0 >=255: len = max8k, data = valid, RET = 0 <255: len = <8k, data = valid, RET = 1 |
BIGBINARY | NULL: len = 0, данные = IG, RET = 1 ZERO: len = IG, data = IG, RET = 0 >=255: len = max8k, data = valid, RET = 0 <255: len = <8k, data = valid, RET = 1 |
BIGVARBINARY | NULL: len = 0, данные = IG, RET = 1 ZERO: len = IG, data = IG, RET = 0 >=255: len = max8k, data = valid, RET = 0 <255: len = <8k, data = valid, RET = 1 |
NCHAR | NULL: len = 0, данные = IG, RET = 1 ZERO: len = IG, data = IG, RET = 0 >=255: len = max8k, data = valid, RET = 0 <255: len = <8k, data = valid, RET = 1 |
NVARCHAR | NULL: len = 0, данные = IG, RET = 1 ZERO: len = IG, data = IG, RET = 0 >=255: len = max8k, data = valid, RET = 0 <255: len = <8k, data = valid, RET = 1 |
NTEXT | NULL: len = IG, data = IG, RET = 0 ZERO: len = IG, data = IG, RET = 0 >=255: len = IG, data = IG, RET = 0 <255: len = IG, data = IG, RET = 0 |
RET = значение, возвращаемое srv_paramset | |
IG = значение будет пропущено | |
valid = любой допустимый указатель на данные |
Замечания
Параметры содержат данные, передаваемые между клиентами и приложением с удаленной хранимой процедурой. Клиент может указать некоторые параметры в качестве возвращаемых. Эти возвращаемые параметры могут содержать значения, которые серверное приложение служб Open Data Services данных передает клиенту. Использование возвращаемых параметров аналогично передаче параметров по ссылке.
Возвращаемое значение невозможно задать параметру, который не был запущен как возвращаемый параметр. Определить, как был вызван параметр, можно с помощью функции srv_paramstatus.
Эта функция задает параметру возвращаемое значение, но она не отправляет это значение клиенту. Все возвращаемые параметры, независимо от того, были ли их возвращаемые значения заданы с помощью функции srv_paramset или нет, автоматически отправляются клиенту при вызове функции srv_senddone с установленным флагом состояния SRV_DONE_FINAL.
Когда удаленная хранимая процедура вызывается с параметрами, эти параметры могут быть переданы либо по имени, либо по позиции — без указания имени. Если при вызове удаленной хранимой процедуры часть параметров передается по имени, а часть — по позиции, возникает ошибка. Обработчик SRV_RPC по-прежнему вызывается, однако он отображается так, как если бы не имел параметров, а функция srv_rpcparams возвращает 0.
Внимание
Необходимо тщательно просмотреть исходный код расширенных хранимых процедур и проверить скомпилированные библиотеки DLL перед их установкой на рабочий сервер. Сведения о проверке безопасности см. на следующем веб-сайте Майкрософт.
См. также
srv_paramsetoutput (API-интерфейс расширенных хранимых процедур)