创建具有指定属性的新的 Parameter 对象。

语法


Set parameter = command.CreateParameter (Name, Type, Direction, Size, Value)

 

例如

 


cm.Parameters.Append cm.CreateParameter("BH", 3, 1,10,rqID)

 

返回值

返回 Parameter 对象。
参数

Name
可选。String 值,包含 Parameter 对象的名称。
Type
可选。DataTypeEnum 值,指定 Parameter 对象的数据类型。
Direction
可选。ParameterDirectionEnum 值,指定 Parameter 对象的类型。
Size
可选。Long 值,指定参数值的最大长度(以字符或字节为单位)。
Value
可选。Variant,指定 Parameter 对象的值。

说明

使用 CreateParameter 方法创建具用指定的名称、类型、方向、大小和值的新的 Parameter 对象。在参数中传送的任何值都将写入相应的 Parameter 属性。

此方法不会将 Parameter 对象自动追加到 Command 对象的 Parameters 集合。这样就可以设置附加属性,在将 Parameter 对象追加到集合时,ADO 将使这些附加属性的值生效。

如果在 Type 参数中指定变长数据类型,在将其追加到 Parameters 集合之前必须传送 Size 参数或者设置 Parameter 对象的 Size 属性;否则将发生错误。

如果在 Type 参数中指定数字型数据类型(adNumeric 或 adDecimal),也必须设置 NumericScale 和 Precision 属性。

 

相关 属性

Type 属性


指示 ParameterField Property 对象的操作类型或数据类型。


设置和返回值


设置或返回下列 DataTypeEnum 值之一。相应的 OLE DB 类型标识符在下表的说明栏的括号中给出。有关 OLE DB 数据类型的详细信息,请参阅第 10 章和《OLE DB 程序员参考》的附录 A。

常量

说明

AdArray

与其他类型一起加入逻辑 OR 以指示该数据是那种类型的安全数组 (DBTYPE_ARRAY)。

AdBigInt

8 字节带符号的整数 (DBTYPE_I8)。

AdBinary

二进制值 (DBTYPE_BYTES)。

AdBoolean

布尔型值 (DBTYPE_BOOL)。

adByRef

与其他类型一起加入逻辑 OR 以指示该数据是其他类型数据的指针 (DBTYPE_BYREF)。

adBSTR

以空结尾的字符串 (Unicode) (DBTYPE_BSTR)。

adChar

字符串值 (DBTYPE_STR)。

adCurrency

货币值 (DBTYPE_CY)。货币数字的小数点位置固定、小数点右侧有四位数字。该值保存为 8 字节范围为 10,000 的带符号整型值。

adDate

日期值 (DBTYPE_DATE)。日期按双精度型数值来保存,数字全部表示从 1899 年 12 月 30 开始的日期数。小数部分是一天当中的片段时间。

adDBDate

日期值 (yyyymmdd) (DBTYPE_DBDATE)。

adDBTime

时间值 (hhmmss) (DBTYPE_DBTIME)。

adDBTimeStamp

时间戳(yyyymmddhhmmss 加 10 亿分之一的小数)(DBTYPE_DBTIMESTAMP).

adDecimal

具有固定精度和范围的精确数字值 (DBTYPE_DECIMAL)。

adDouble

双精度浮点值 (DBTYPE_R8)。

adEmpty

未指定值 (DBTYPE_EMPTY)。

adError

32 - 位错误代码 (DBTYPE_ERROR)。

adGUID

全局唯一的标识符 (GUID) (DBTYPE_GUID)。

adIDispatch

OLE 对象上 Idispatch 接口的指针 (DBTYPE_IDISPATCH)。

adInteger

4 字节的带符号整型 (DBTYPE_I4)。

adIUnknown

OLE 对象上 IUnknown 接口的指针 (DBTYPE_IUNKNOWN)。

adLongVarBinary

长二进制值(仅用于 Parameter 对象)。

adLongVarChar

字符串值(仅用于 Parameter 对象)。

adLongVarWChar

以空结尾的长字符串值(仅用于 Parameter 对象)。

adNumeric

具有固定精度和范围的精确数字值 (DBTYPE_NUMERIC)。

adSingle

单精度浮点值 (DBTYPE_R4)。

adSmallInt

2 字节带符号整型 (DBTYPE_I2)。

adTinyInt

1 字节带符号整型 (DBTYPE_I1)。

adUnsignedBigInt

8 字节不带符号整型 (DBTYPE_UI8)。

adUnsignedInt

4 字节不带符号整型 (DBTYPE_UI4)。

adUnsignedSmallInt

2 字节不带符号整型 (DBTYPE_UI2)。

adUnsignedTinyInt

1 字节不带符号整型 (DBTYPE_UI1)。

adUserDefined

用户定义的变量 (DBTYPE_UDT)。

adVarBinary

二进制值(仅 Parameter 对象)。

adVarChar

字符串值(仅 Parameter 对象)。

adVariant

自动变体型 (DBTYPE_VARIANT)。

adVector

与其他类型一起加入逻辑 OR 中,指示数据是 DBVECTOR 结构(由 OLE DB 定义)。该结构含有元素的计数和其他类型 (DBTYPE_VECTOR) 数据的指针。

adVarWChar

以空结尾的 Unicode 字符串(仅 Parameter 对象)。

adWChar

以空结尾的 Unicode 字符串 (DBTYPE_WSTR)。

 


说明


Parameter 对象, Type 属性是读/写。对其他所有对象, Type 属性是只读。


 

Direction 属性


指示 Parameter 所标明的是输入参数、输出参数还是既是输出又是输入参数,或该参数是否为存储过程返回的值。

设置和返回值

设置或返回以下某个 ParameterDirectionEnum 值。

常量

说明

AdParamUnknown

指示参数方向未知。

AdParamInput

默认值。指示输入参数。

AdParamOutput

指示输出参数。

AdParamInputOutput

同时指示输入参数和输出参数。

AdParamReturnValue

指示返回值。




说明



使用 Direction 属性可指定向过程传递参数或从过程传递参数的方式。Direction 属性为读/写;该属性允许使用不返回该信息的提供者,或者在不希望 ADO 为了获取参数信息而附加调用提供者时设置该信息。



并非所有的提供者都可以在其存储过程中确定参数方向。在此情况下,在执行查询前必须设置 Direction 属性。

Size 属性


表示 Parameter 对象的最大大小(按字节或字符)。

设置和返回数值

设置或返回表示 Parameter 对象的最大大小(按字节或字符)的长整型值。

说明

使用 Size 属性确定对 Parameter 对象的 Value 属性写入(或读出)值的最大大小。Size 属性为可读/写。

如果要指定 Parameter 对象为变长数据类型(例如任何字符串类型,如 adVarChar),则必须先设置对象的 Size 属性,然后再将该对象追加到 Parameters 集合。否则,将会出现错误。

如果已经将 Parameter 对象追加到 Command 对象的 Parameter 集合,并已经将它的类型更改为变长数据类型,那么必须先设置 Parameter 对象的 Size 属性然后再执行 Command 对象。否则,将出现错误。

如果使用 Refresh 方法从提供者获取参数信息,并且它返回一个或多个变长数据类型 Parameter 对象,ADO 可能会根据其最大可能的大小为其分配内存空间,这样在执行中可能会导致错误。为避免出错,应该在执行命令之前显式设置这些参数的 Size 属性。