A stored procedure is a precompiled executable object that contains one or more SQL statements. Stored procedures can have input and output parameters and can also put out an integer return code. An application can enumerate available stored procedures by using catalog functions.
ODBC applications targeting SQL Server should only use direct execution to call a stored procedure. When connected to earlier versions of SQL Server, the SQL Server ODBC driver implements SQLPrepare by creating a temporary stored procedure, which is then called on SQLExecute. It adds overhead to have SQLPrepare create a temporary stored procedure that only calls the target stored procedure versus directly executing the target stored procedure. Even when connected to SQL Server version 7.0, preparing a call requires an extra round trip across the network and the building of an execution plan that just calls the stored procedure execution plan.
ODBC applications should use the ODBC CALL syntax when executing a stored procedure. The driver is optimized to use a remote procedure call (RPC) mechanism to call the procedure when the ODBC CALL syntax is used. This is more efficient than the mechanism used to send a Transact-SQL EXECUTE statement to the server.
For more information, see Running Stored Procedures.
To call remote procedures
SQLMoreResults | SQLPrepare |