OLE DB 資料表值參數類型支援 (方法)
下列標準 OLE DB 方法支援資料表值參數:
方法 |
資料表值參數支援 |
---|---|
ITableDefinitionWithConstraints::CreateTableWithConstraints |
當您知道資料表值參數的類型資訊,而且想要根據類型資訊來具現化資料表值參數資料列集物件時使用。 如需詳細資訊,請參閱<建立資料表值參數資料列集>中的<靜態案例>。 |
IOpenRowset::OpenRowset |
當您不知道資料表值參數的類型資訊,而且想要根據從伺服器擷取的中繼資料資訊來具現化資料表值參數資料列集物件時使用。 如需詳細資訊,請參閱<建立資料表值參數資料列集>中的<動態案例>。 |
ISSCommandWithParameters::SetParameterInfo |
若要指定資料表值參數命令參數,取用者會在 DBPARAMBINDINFO 結構的 pwszName 成員中將此參數的類型指定為 "table" 或 "DBTYPE_TABLE"。 ulParamSize 會設定為 ~0。 如需詳細資訊,請參閱<執行包含資料表值參數的命令>中的<資料表值參數規格>。 |
ISSCommandWithParameters::SetParameterProperties |
會設定資料表值參數所特有的屬性,例如結構描述名稱、類型名稱、資料行順序和預設資料行。 取用者會在 SSPARAMPROPS 結構的 iOrdinal 中指定參數的序數。 所要求的屬性集為 DBPROPSET_SQLSERVERPARAMETER。 |
ISSCommandWithParameters::GetParameterInfo |
取得指定之命令的所有參數類型。 如果是資料表值參數,DBPARAMINFO 結構中的 wType 欄位將會具有 DBTYPE_TABLE 類型。 ulParamSize 欄位將會設定為 ~0,表示長度未知。 |
ISSCommandWithParameters::GetParameterProperties |
取得 DBTYPE_TABLE 類型之參數的其他類型資訊。 取用者會在 SSPARAMPROPS 結構的 iOrdinal 成員中指定參數的序數。 取用者可以在 DBPROPSET_SQLSERVERPARAMETER 屬性集中要求列在 ISSCommandWithParameters::SetParameterProperties 底下的任何屬性。 因為取用者不知道資料表值參數類型,所以提供者必須將 SSPROP_PARAM_TYPE_TYPENAME、SSPROP_PARAM_TYPE_SCHEMANAME 和 SSPROP_PARAM_TYPE_CATALOGNAME 設定為正確的值。 其餘的 SSPROP_PARAM_TABLE_DEFAULT_COLUMNS 和 SSPROP_PARAM_TABLE_COLUMN_SORT_ORDER 屬性將會有預設值。 當取用者已經探索出資料表值參數類型名稱時,它會使用 IOpenRowset::OpenRowset 來建立這個資料表值參數的執行個體,指定資料表值參數類型的名稱。 如需詳細資訊,請參閱<資料表值參數類型探索>。 |
IRowsetInfo::GetProperties |
取得資料表值參數資料列集屬性。 取用者可以使用這些屬性,以最佳方式設定繫結。 |
IColumnsRowset::GetColumnsRowset |
擷取有關 SQL Server 資料表的中繼資料資訊。 如果是資料表值參數,這個相同介面會提供有關每一個資料行的詳細中繼資料資訊,如下所示:
|
IAccessor::CreateAccessor |
若要將資料表值參數資料列集物件繫結到命令參數,當您建立存取子時,請將它的 wType 成員設定為 DBTYPE_TABLE。 DBOBJECT 結構將會包含 IID_IRowset 或是 iid 成員中任何其他有效的資料列集物件介面。 其餘欄位的處理方式類似於 DBTYPE_IUNKNOWN。 |