Compartilhar via


Referenciar uma propriedade no seu provedor

Encontre o grupo de propriedade e a identificação de propriedade para a propriedade desejada.Para obter mais informações, consulte OLE DB propriedades na OLE DB Programmer referência.

O exemplo a seguir pressupõe que você está tentando obter uma propriedade do conjunto de linhas.O código para usar o comando ou sessão é semelhante, mas usa uma interface diferente.

Criar um CDBPropSet usando o grupo de propriedade como parâmetro para o construtor de objeto.Por exemplo:

CDBPropSet propset(DBPROPSET_ROWSET);

Chamar AddProperty, passando a identificação de propriedade e um valor a ser atribuído à propriedade.O tipo do valor depende a propriedade que você está usando.

CDBPropSet propset(DBPROPSET_ROWSET);
propset.AddProperty(DBPROP_IRowsetChange, true);
propset.AddProperty(DBPROP_UPDATABILITY,
DBPROPVAL_UP_INSERT | DBPROPVAL_UP_CHANGE | DBPROPVAL_UP_DELETE);

Use o IRowset interface chamada GetProperties.Passe a propriedade definida como um parâmetro.Aqui está o código final:

CAgentRowset<CMyProviderCommand>* pRowset = (CAgentRowset<CMyProviderCommand>*) pThis;

CComQIPtr<IRowsetInfo, &IID_IRowsetInfo> spRowsetProps = pRowset;

DBPROPIDSET set;
set.AddPropertyID(DBPROP_BOOKMARKS);
DBPROPSET* pPropSet = NULL;
ULONG ulPropSet = 0;
HRESULT hr;

if (spRowsetProps)
   hr = spRowsetProps->GetProperties(1, &set, &ulPropSet, &pPropSet);

if (pPropSet)
{
   CComVariant var = pPropSet->rgProperties[0].vValue;
   CoTaskMemFree(pPropSet->rgProperties);
   CoTaskMemFree(pPropSet);

   if (SUCCEEDED(hr) && (var.boolVal == VARIANT_TRUE))
   {
      ...  // Use property here
   }
}

Consulte também

Conceitos

Trabalhando com modelos do provedor OLE DB