db_command
Crea un comando OLE DB.
[ db_command(
command,
name,
source_name,
hresult,
bindings,
bulk_fetch)
]
Parametri
command
Una stringa di comando che contiene il testo di un comando OLE DB. Un semplice esempio è:[ db_command ( command = "Select * from Products" ) ]
comando la sintassi è la seguente:
binding parameter block 1 OLE DB command binding parameter block 2 continuation of OLE DB command binding parameter block 3 ...
In blocco obbligatorio di parametro viene definito come segue:
([bindtype**]** szVar1 [, szVar2 [, nVar3 [,]…]] )
Dove:
( contrassegna l'inizio del blocco di associazione dati.
[bindtype] è una delle stringhe senza distinzione tra maiuscole e minuscole:
[db_column] associa ciascuna delle variabili membro a una colonna in un rowset.
[bindto] (equivale a [db_column]).
[in] associa le variabili membro come parametri di input.
[out] associa le variabili membro come parametri di output.
[in, out] associa le variabili membro come parametri di input/output.
SzVarX punta a una variabile membro nell'ambito corrente.
) contrassegna la fine del blocco di associazione dati.
se la stringa di comando contiene uno o più identificatori come [in] [out], o [in/out], db_command compila una mappa dei parametri.
se la stringa di comando contiene uno o più parametri come [db_column] o [bindto], db_command genera un rowset e un mapping della funzione di accesso per soddisfare queste variabili associate. vedere db_accessor per ulteriori informazioni.
Nota
[bindtype] sintassi e bindings il parametro non è valido in caso di utilizzo db_command a livello di classe.
Di seguito sono riportati alcuni esempi di blocchi di associazione di parametro. Nell'esempio seguente viene associato m_au_fname e m_au_lname membri dati a au_fname e au_lname colonne, rispettivamente, della tabella authors del database pubs:
TCHAR m_au_fname[21]; TCHAR m_au_lname[41]; TCHAR m_state[3] = 'CA'; [db_command ( command = "SELECT au_fname([bindto]m_au_fname), au_lname([bindto]m_au_lname) " \ "FROM dbo.authors " \ "WHERE state = ?([in]m_state)")
]
nome (facoltativo)
Il nome dell'handle utilizzati per utilizzare il rowset. Se si specifica nome, db_command genera una classe con specificato nome, che può essere utilizzato per scorrere il rowset o per eseguire query di azione più. Se non si specifica nome, non sarà possibile restituire più righe di risultati all'utente.source_name (facoltativo)
CSession variabile o istanza di una classe che ha db_source attributo applicato a sul quale il comando viene eseguito. vedere db_source.db_command controlli da garantire che la variabile utilizzata per source_name è valido, pertanto la variabile specificata deve trovarsi nella funzione o nell'ambito globale.
hresult (facoltativo)
identifica la variabile che riceverà HRESULT di questo comando di database. Se la variabile non esiste, verrà automaticamente inserita dall'attributo.associazioni (facoltativo)
Consente di separare i parametri richiesti dal comando OLE DB.Se si specifica un valore per bindings, db_command analizza il valore associato e non analizza [bindtype] parametro. Questo utilizzo consente di sintassi provider OLE DB di utilizzo. per disabilitare l'analisi, senza parametri obbligatori, specificare "" Di Bindings=.
Se non si specifica un valore per bindings, db_command analizza il blocco obbligatorio di parametro, trovando '(“, seguito da [bindtype] tra parentesi, seguiti da uno o più precedentemente dichiarata le variabili membro di C++, seguiti da serializzarne**)**“. Tutto il testo tra le parentesi verrà rimosso dal comando risultante e questi parametri saranno utilizzati per costruire la colonna e le associazioni di parametri per questa sequenza.
bulk_fetch(facoltativo)
Un valore intero che specifica il numero di righe da recuperare.Il valore predefinito è 1, che specifica solo il recupero della riga (rowset di sarà di tipo CRowset).
Un valore maggiore di 1 specifica il recupero di massa di righe. Il recupero di massa di righe " si riferisce alla possibilità dei rowset di massa di recuperare l'handle di riga più (rowset di sarà di tipo CBulkRowset e chiamerà SetRows con il numero specificato di righe).
se bulk_fetch è minore di uno, SetRows restituirà zero.
Note
db_command crea un oggetto Di CCommand oggetto, utilizzato da un consumer OLE DB per eseguire un comando.
È possibile utilizzare db_command con classe o dell'ambito della funzione, la differenza principale è l'ambito di l CCommand oggetto. Nell'ambito della funzione, i dati come associazioni terminano alla fine della funzione. Sia gli utilizzi dell'ambito della funzione della classe includono la classe di modelli consumer OLE DB CCommand<>, ma gli argomenti di template differiscono per i casi della classe e di funzione. Nel caso di funzione, le associazioni verranno apportate a funzione di accesso che include le variabili locali, mentre l'utilizzo della classe a desumere un oggetto CAccessorclasse derivata da come argomento. Una volta utilizzato come attributo della classe, db_command opera congiuntamente a db_column.
db_command può essere utilizzato per eseguire i comandi che restituiscono un gruppo di risultati.
Quando il provider di tipo consumer di attributo applicato questo attributo a una classe, il compilatore la classe a _TheClassNamefunzione di accesso, dove TheClassName è il nome assegnato alla classe e il compilatore inoltre creata una classe denominata TheClassName, quale deriva da _TheClassNamefunzione di accesso. In Visualizzazione classi, verranno visualizzate entrambe le classi.
Esempio
In questo esempio viene definito un comando che consente di selezionare il primo e il cognome da una tabella in cui la CA di stato delle corrispondenze della colonna„. db_command crea e legge un rowset in cui è possibile chiamare le funzioni generate mediante la creazione guidata come OpenAll e CloseAllnonché CRowset funzioni membro come MoveNext.
Si noti che questo codice è necessario specificare per contenere la stringa di connessione che connette a pub il database. Per informazioni su come eseguire questa operazione nell'ambiente di sviluppo, vedere Procedura: connettersi a un database da Esplora server e Procedura: Aggiungere nuove connessioni dati in Esplora server/Esplora database.
// db_command.h
#include <atlbase.h>
#include <atlplus.h>
#include <atldbcli.h>
#pragma once
[ db_source(L"your connection string"),
db_command(L" \
SELECT au_lname, au_fname \
FROM dbo.authors \
WHERE state = 'CA'") ]
struct CAuthors {
// In order to fix several issues with some providers, the code below may bind
// columns in a different order than reported by the provider
DBSTATUS m_dwau_lnameStatus;
DBSTATUS m_dwau_fnameStatus;
DBLENGTH m_dwau_lnameLength;
DBLENGTH m_dwau_fnameLength;
[ db_column("au_lname", status="m_dwau_lnameStatus", length="m_dwau_lnameLength") ] TCHAR m_au_lname[41];
[ db_column("au_fname", status="m_dwau_fnameStatus", length="m_dwau_fnameLength") ] TCHAR m_au_fname[21];
[ db_param("7", paramtype="DBPARAMIO_INPUT") ] TCHAR m_state[3];
void GetRowsetProperties(CDBPropSet* pPropSet) {
pPropSet->AddProperty(DBPROP_CANFETCHBACKWARDS, true, DBPROPOPTIONS_OPTIONAL);
pPropSet->AddProperty(DBPROP_CANSCROLLBACKWARDS, true, DBPROPOPTIONS_OPTIONAL);
}
};
// db_command.cpp
// compile with: /c
#include "db_command.h"
int main(int argc, _TCHAR* argv[]) {
HRESULT hr = CoInitialize(NULL);
// Instantiate rowset
CAuthors rs;
// Open rowset and move to first row
strcpy_s(rs.m_state, sizeof(rs.m_state), _T("CA"));
hr = rs.OpenAll();
hr = rs.MoveFirst();
// Iterate through the rowset
while( SUCCEEDED(hr) && hr != DB_S_ENDOFROWSET ) {
// Print out the column information for each row
printf("First Name: %s, Last Name: %s\n", rs.m_au_fname, rs.m_au_lname);
hr = rs.MoveNext();
}
rs.CloseAll();
CoUninitialize();
}
In questo esempio viene utilizzato db_source in una classe di origine dati CMySourcee db_command le classi dei comandi CCommand1 e CCommand2.
// db_command_2.cpp
// compile with: /c
#include <atlbase.h>
#include <atlplus.h>
#include <atldbcli.h>
// class usage for both db_source and db_command
[ db_source(L"your connection string"),
db_command(L" \
SELECT au_lname, au_fname \
FROM dbo.authors \
WHERE state = 'CA'") ]
struct CMySource {
HRESULT OpenDataSource() {
return S_OK;
}
};
[db_command(command = "SELECT * FROM Products")]
class CCommand1 {};
[db_command(command = "SELECT FNAME, LNAME FROM Customers")]
class CCommand2 {};
int main() {
CMySource s;
HRESULT hr = s.OpenDataSource();
if (SUCCEEDED(hr)) {
CCommand1 c1;
hr = c1.Open(s);
CCommand2 c2;
hr = c2.Open(s);
}
s.CloseDataSource();
}
Requisiti
contesto di attributo
Si applica a |
classe, struct, membro, metodo, locale |
ripetibile |
No |
attributi obbligatori |
Nessuno |
attributi non validi |
Nessuno |
per ulteriori informazioni sui contesti di attributo, vedere Associare ai contesti.