Condividi tramite


Procedura: Impostare dati di grandi dimensioni (OLE DB)

Per passare un puntatore al relativo oggetto di archiviazione, il consumer crea una funzione di accesso che associa il valore della colonna BLOB e quindi chiama il metodo IRowsetChange::SetData o IRowsetChange::InsertRow.

Procedure

Per impostare dati BLOB

  1. Creare una struttura DBOBJECT che descrive il modo in cui accedere alla colonna BLOB. Impostare l'elemento dwFlag della struttura DBOBJECT su STGM_READ e impostare l'elemento iid su IID_ISequentialStream, ovvero l'interfaccia da esporre.

  2. Impostare le proprietà nel gruppo di proprietà DBPROPSET_ROWSET in modo che il set di righe sia aggiornabile.

  3. Creare un set di associazioni, uno per ogni colonna, utilizzando una matrice di strutture DBBINDING. Impostare l'elemento wType nella struttura DBBINDING su DBTYPE_IUNKNOWN e l'elemento pObject in modo che punti alla struttura DBOBJECT creata.

  4. Creare una funzione di accesso utilizzando le informazioni di associazione nella matrice di strutture DBBINDINGS.

  5. Chiamare GetNextRows per recuperare le righe successive nel set di righe. Chiamare GetData per leggere i dati dal set di righe.

  6. Per impostare i dati, creare un oggetto di archiviazione contenente i dati (e anche l'indicatore di lunghezza) e quindi chiamare IRowsetChange::SetData (o IRowsetChange::InsertRow) con la funzione di accesso che associa la colonna BLOB.

Osservazioni

Il codice di esempio completo è disponibile nel file WorkingWithBLOBs.cpp. È possibile scaricare un archivio contenente l'esempio dalla pagina SQL Server Downloads su MSDN.

L'esempio è stato sviluppato utilizzando Microsoft Visual C++ 2005.

Nota sulla sicurezzaNota sulla sicurezza

Se possibile, utilizzare l'autenticazione di Windows. Se non è disponibile, verrà richiesto agli utenti di immettere le credenziali in fase di esecuzione. Evitare di archiviare le credenziali in un file. Se è necessario rendere persistenti le credenziali, è consigliabile crittografarle utilizzando CryptoAPI Win32.