Condividi tramite


Esecuzione di una chiamata a una stored procedure (OLE DB)

Una stored procedure può avere zero o più parametri. Può inoltre restituire un valore. Quando si utilizza il provider OLE DB di SQL Server Native Client, è possibile passare i parametri in una stored procedure nel modo seguente:

  • Specificando il valore dei dati a livello di codice.

  • Utilizzando un indicatore di parametro (?) per specificare i parametri, associare una variabile di programma all'indicatore di parametro e quindi inserire il valore dei dati nella variabile di programma.

Nota

Quando si esegue una chiamata alle stored procedure SQL Server utilizzando parametri denominati con OLE DB, i nomi dei parametri devono iniziare con il carattere '@'. Si tratta di una restrizione specifica di SQL Server. Il provider OLE DB di SQL Server Native Client applica questa limitazione in modo più restrittivo rispetto a MDAC.

Per supportare i parametri, l'interfaccia ICommandWithParameters viene esposta nell'oggetto comando. Per utilizzare i parametri, il consumer descrive prima i parametri al provider chiamando il metodo ICommandWithParameters::SetParameterInfo (o facoltativamente prepara un'istruzione di chiamata che chiama il metodo GetParameterInfo). Il consumer crea quindi una funzione di accesso che specifica la struttura di un buffer e inserisce i valori dei parametri in questo buffer. Infine, passa l'handle della funzione di accesso e un puntatore al buffer a Execute. Nelle chiamate successive a Execute, il consumer inserisce i nuovi valori dei parametri nel buffer e chiama Execute con l'handle della funzione di accesso e il puntatore al buffer.

Un comando che chiama una stored procedure temporanea mediante i parametri deve prima chiamare ICommandWithParameters::SetParameterInfo per definire le informazioni sui parametri, affinché il comando possa essere preparato correttamente. Questa operazione è necessaria perché il nome interno di una stored procedure temporanea è diverso dal nome esterno utilizzato da un client e SQLOLEDB non può eseguire una query sulle tabelle di sistema per determinare le informazioni sui parametri per una stored procedure temporanea.

Di seguito sono riportati i passaggi del processo di associazione dei parametri:

  1. Completare le informazioni sui parametri in una matrice di strutture DBPARAMBINDINFO, ovvero nome del parametro, nome specifico del provider per il tipo di dati del parametro o nome del tipo di dati standard e così via. Ogni struttura della matrice descrive un solo parametro. Questa matrice viene quindi passata al metodo SetParameterInfo.

  2. Chiamare il metodo ICommandWithParameters::SetParameterInfo per descrivere i parametri al provider. SetParameterInfo specifica il tipo di dati nativo di ogni parametro. Gli argomenti di SetParameterInfo sono:

    • Numero di parametri per i quali impostare le informazioni sul tipo.

    • Matrice di numeri ordinali dei parametri per i quali impostare le informazioni sul tipo.

    • Matrice di strutture DBPARAMBINDINFO.

  3. Creare una funzione di accesso ai parametri mediante il comando IAccessor::CreateAccessor. La funzione di accesso specifica la struttura di un buffer e inserisce i valori dei parametri nel buffer. Il comando CreateAccessor crea una funzione di accesso da un set di associazioni. Queste associazioni vengono descritte dal consumer mediante una matrice di strutture DBBINDING. Ogni associazione associa un singolo parametro al buffer del consumer e contiene le seguenti informazioni:

    • Numero ordinale del parametro a cui viene applicata l'associazione.

    • Elemento da associare (valore dei dati, lunghezza e stato).

    • Offset nel buffer per ognuna di queste parti.

    • Lunghezza e tipo del valore dei dati esattamente come riportati nel buffer del consumer.

    Una funzione di accesso viene identificata dal relativo handle di tipo HACCESSOR. Questo handle viene restituito dal metodo CreateAccessor. Al termine dell'utilizzo di una funzione di accesso, il consumer deve chiamare il metodo ReleaseAccessor per rilasciarne la memoria.

    Quando il consumer chiama un metodo, ad esempio ICommand::Execute, passa l'handle a una funzione di accesso e a un puntatore a un buffer. Il provider utilizza questa funzione di accesso per determinare il modo in cui trasferire i dati contenuti nel buffer.

  4. Completare la struttura DBPARAMS. Le variabili del consumer, da cui vengono acquisiti i valori dei parametri di input e in cui vengono scritti i valori dei parametri di output, vengono passate in fase di esecuzione a ICommand::Execute nella struttura DBPARAMS. La struttura DBPARAMS include tre elementi:

    • Puntatore al buffer da cui il provider recupera i dati dei parametri di input e in cui il provider restituisce i dati dei parametri di output, in base alle associazioni specificate dall'handle della funzione di accesso.

    • Numero di set di parametri nel buffer.

    • Handle della funzione di accesso creato nel passaggio 3.

  5. Eseguire il comando mediante ICommand::Execute.

Metodi per l'esecuzione di una chiamata a una stored procedure

Quando si esegue una stored procedure in SQL Server, il provider OLE DB di SQL Server Native Client supporta i seguenti elementi:

  • Sequenza di escape ODBC CALL.

  • Sequenza di escape RPC (Remote Procedure Call).

  • Istruzione Transact-SQLEXECUTE.

Sequenza di escape ODBC CALL

Se si conoscono le informazioni sui parametri, chiamare il metodo ICommandWithParameters::SetParameterInfo per descrivere i parametri al provider. In caso contrario, quando viene utilizzata la sintassi ODBC CALL per eseguire la chiamata a una stored procedure, il provider chiama una funzione di supporto per trovare le informazioni sui parametri della stored procedure.

Se non si è certi delle informazioni sui parametri (metadati dei parametri), è consigliata la sintassi ODBC CALL.

La sintassi generale per la chiamata a una stored procedure mediante la sequenza di escape ODBC CALL è:

{[?=]callprocedure_name[([parameter][,[parameter]]...)]}

Esempio:

{call SalesByCategory('Produce', '1995')}

Sequenza di escape RPC

La sequenza di escape RPC è simile alla sintassi ODBC CALL della chiamata a una stored procedure. Se si chiama la stored procedure più volte, la sequenza di escape RPC offre le massime prestazioni tra i tre metodi utilizzati per chiamare una stored procedure.

Quando la sequenza di escape RPC viene utilizzata per eseguire una stored procedure, il provider non chiama la funzione di supporto per determinare le informazioni sui parametri (come avviene nel caso della sintassi ODBC CALL). La sintassi RPC è più semplice della sintassi ODBC CALL, pertanto il comando viene analizzato più velocemente, migliorando le prestazioni. In questo caso, è necessario fornire le informazioni sui parametri eseguendo ICommandWithParameters::SetParameterInfo.

Per utilizzare la sequenza di escape RPC è necessario disporre di un valore restituito. Se la stored procedure non restituisce un valore, il server restituisce per impostazione predefinita il valore 0. Inoltre, non è possibile aprire un cursore SQL Server nella stored procedure. La stored procedure viene preparata in modo implicito e la chiamata a ICommandPrepare::Prepare avrà esito negativo. A causa dell'impossibilità di preparare una chiamata RPC, non è possibile eseguire una query sui metadati delle colonne; IColumnsInfo::GetColumnInfo e IColumnsRowset::GetColumnsRowset restituiranno DB_E_NOTPREPARED.

Se si conoscono tutti i metadati dei parametri, la sequenza di escape RPC è la modalità consigliata per eseguire le stored procedure.

Di seguito viene riportato un esempio di sequenza di escape RPC per la chiamata a una stored procedure:

{rpc SalesByCategory}

In CodePlex è disponibile un'applicazione di esempio che illustra una sequenza di escape RPC; per ulteriori informazioni, vedere Esempi del Motore di database di SQL Server.

Istruzione Transact-SQL EXECUTE

La sequenza di escape ODBC CALL e la sequenza di escape RPC rappresentano i metodi preferiti per la chiamata a una stored procedure rispetto all'istruzione EXECUTE. Il provider OLE DB di SQL Server Native Client utilizza il meccanismo RPC di SQL Server per ottimizzare l'elaborazione del comando. Questo protocollo RPC migliora le prestazioni riducendo l'elaborazione dei parametri e l'analisi delle istruzioni eseguite sul server.

Di seguito è riportato un esempio dell'istruzione Transact-SQLEXECUTE:

EXECUTE SalesByCategory 'Produce', '1995'

Vedere anche

Altre risorse