Función SQLCancelHandle
de conformidad de
Versión introducida: Cumplimiento de estándares ODBC 3.8: Ninguno
Se espera que la mayoría de los controladores ODBC 3.8 (y versiones posteriores) implementen esta función. Si un controlador no lo hace, Una llamada a
resumen
SQLCancelHandle cancela el procesamiento en una conexión o instrucción. El Administrador de controladores asigna una llamada a SQLCancelHandle a una llamada a sqlCancel cuando se SQL_HANDLE_STMT handleType.
Sintaxis
SQLRETURN SQLCancelHandle(
SQLSMALLINT HandleType,
SQLHANDLE Handle);
Argumentos
handleType
[Entrada] Tipo del identificador en el que se va a cancelar el procesamiento. Los valores válidos son SQL_HANDLE_DBC o SQL_HANDLE_STMT.
de identificador
[Entrada] Identificador en el que se cancela el procesamiento.
Si handle no es un identificador válido del tipo especificado por HandleType, sqlCancelHandle devuelve SQL_INVALID_HANDLE.
Devuelve
SQL_SUCCESS, SQL_SUCCESS_WITH_INFO, SQL_ERROR o SQL_INVALID_HANDLE.
Diagnósticos
Cuando sqlCancelHandle devuelve SQL_ERROR o SQL_SUCCESS_WITH_INFO, se puede obtener un valor SQLSTATE asociado llamando a SQLGetDiagRec con un HandleType de SQL_HANDLE_STMT y una instrucción handle Handle o un HandleType de SQL_HANDLE_DBC y un identificador de conexión Handle.
En la tabla siguiente se enumeran los valores SQLSTATE devueltos normalmente por sqlCancelHandle y se explica cada uno en el contexto de esta función; la notación "(DM)" precede a las descripciones de SQLSTATEs devueltas por el Administrador de controladores. El código de retorno asociado a cada valor SQLSTATE es SQL_ERROR, a menos que se indique lo contrario.
SQLSTATE | Error | Descripción |
---|---|---|
01000 | Advertencia general | Mensaje informativo específico del controlador. (Function devuelve SQL_SUCCESS_WITH_INFO). |
HY000 | Error general | Se produjo un error para el que no había ningún SQLSTATE específico y para el que no se definió SQLSTATE específico de la implementación. El mensaje de error devuelto por SQLGetDiagRec en el argumento *MessageText buffer describe el error y su causa. |
HY001 | Error de asignación de memoria | El controlador no pudo asignar memoria necesaria para admitir la ejecución o finalización de la función. |
HY010 | Error de secuencia de funciones | Se llamó a una función relacionada con instrucciones que se ejecuta de forma asincrónica para uno de los identificadores de instrucción asociados a la Handley HandleType se estableció en SQL_HANDLE_DBC. La función asincrónica todavía se estaba ejecutando cuando se llamó a sqlCancelHandle. (DM) El argumento HandleType era SQL_HANDLE_STMT; se llamó a una función de ejecución asincrónica en el identificador de conexión asociado; y la función todavía se estaba ejecutando cuando se llamó a esta función. (DM) sqlExecute, SQLExecDirect, o sqlMoreResults se llamó a para uno de los identificadores de instrucción asociados con Handle y HandleType se estableció en SQL_HANDLE_DBC y se devolvió SQL_PARAM_DATA_AVAILABLE. Se llamó a esta función antes de recuperar los datos para todos los parámetros transmitidos. se llamó a la SQLBrowseConnect para ConnectionHandley devolvió SQL_NEED_DATA. Se llamó a esta función antes de que se complete el proceso de exploración. |
HY013 | Error de administración de memoria | No se pudo procesar la llamada de función porque no se pudo tener acceso a los objetos de memoria subyacentes, posiblemente debido a condiciones de memoria baja. |
HY092 | Identificador de atributo o opción no válido | handleType se estableció en SQL_HANDLE_ENV o SQL_HANDLE_DESC. |
HY117 | La conexión se suspende debido al estado de transacción desconocido. Solo se permiten las funciones de desconexión y solo lectura. | (DM) Para obtener más información sobre el estado suspendido, vea función SQLEndTran. |
HYT01 | Tiempo de espera de conexión expirado | El período de tiempo de espera de conexión expiró antes de que el origen de datos respondiera a la solicitud. El período de tiempo de espera de conexión se establece a través de SQLSetConnectAttr, SQL_ATTR_CONNECTION_TIMEOUT. |
IM001 | El controlador no admite esta función | (DM) El controlador asociado al handle no admite la función . |
Si se llama a SQLCancelHandle con HandleType establecido en SQL_HANDLE_STMT, puede devolver cualquier SQLSTATE que pueda devolver la función SQLCancel.
Comentarios
Esta función es similar a sqlCancel, pero puede tomar una conexión o un identificador de instrucción como parámetro en lugar de solo un identificador de instrucción. El Administrador de controladores asigna una llamada a SQLCancelHandle a una llamada a sqlCancel cuando se SQL_HANDLE_STMT handleType. Esto permite que las aplicaciones usen SQLCancelHandle para cancelar las operaciones de instrucciones aunque el controlador no implemente SQLCancelHandle.
Para obtener más información sobre cómo cancelar una operación de instrucción, vea función SQLCancel.
Si no hay ninguna operación en curso en Handle la llamada a SQLCancelHandle no tiene ningún efecto.
SQLCancelHandle en un identificador de conexión puede cancelar los siguientes tipos de procesamiento:
Función que se ejecuta de forma asincrónica en la conexión.
Función que se ejecuta en el identificador de conexión en otro subproceso.
Cuando se llama a sqlCancelHandle para cancelar una función que se ejecuta de forma asincrónica en una conexión, los registros de diagnóstico publicados por sqlCancelHandle se anexan a los devueltos por la operación que se cancela; SQLCancelHandle no devuelve registros de diagnóstico, sin embargo, al cancelar una función que se ejecuta en una conexión en otro subproceso.
El uso de sqlCancelHandle para cancelar sqlEndTran puede poner la conexión en estado suspendido. Para obtener más información sobre el estado suspendido, vea función SQLEndTran.
Nota
Para obtener información sobre cómo usar SQLCancelHandle en una aplicación que se implementará en un sistema operativo Windows anterior a Windows 7, consulte Matriz de compatibilidad.
Cancelación del procesamiento asincrónico de Connection-Related
Si una función devuelve SQL_STILL_EXECUTING, una aplicación puede llamar a sqlCancelHandle para cancelar la operación. Si la solicitud de cancelación se realiza correctamente, sqlCancelHandle devuelve SQL_SUCCESS. Esto no significa que se canceló la función original; indica que se procesó la solicitud de cancelación. El controlador y el origen de datos determinan cuándo o si se cancela la operación. La aplicación debe seguir llamando a la función original hasta que el código devuelto no sea SQL_STILL_EXECUTING. Si se canceló la función original, el código de retorno es SQL_ERROR y SQLSTATE HY008 (operación cancelada). Si la función original completó su procesamiento normal (no se canceló), el código de retorno se SQL_SUCCESS o SQL_SUCCESS_WITH_INFO, o SQL_ERROR y un VALOR SQLSTATE distinto de HY008 (operación cancelada), si se produjo un error en la función original.
Cancelación de funciones que se ejecutan en otro subproceso
En una aplicación multiproceso, la aplicación puede cancelar una operación que se ejecuta en otro subproceso. Para cancelar la operación, la aplicación llama a SQLCancelHandle con el identificador usado por la función, pero en un subproceso diferente. El controlador y el sistema operativo determinan cómo se cancela la operación. El código devuelto de SQLCancelHandle indica si el controlador procesó la solicitud, devolviendo SQL_SUCCESS o SQL_ERROR (no se devuelve información de diagnóstico). Si se cancela el procesamiento en la función original, la función original devuelve SQL_ERROR y SQLSTATE HY008 (operación cancelada).
Si se ejecuta una función cuando se llama a sqlCancelHandle en otro subproceso para cancelar la función, es posible que la función se realice correctamente y devuelva SQL_SUCCESS antes de que la cancelación pueda surtir efecto. Una llamada a sqlCancelHandle no tiene ningún efecto si la operación se completó antes de SQLCancelHandle pudo cancelar la operación.
Funciones relacionadas
Para obtener información sobre | Ver |
---|---|
Cancelar una función que se ejecuta de forma asincrónica en un identificador de instrucción, cancelar una función en una instrucción que necesite datos o cancelar una función que se ejecute en una instrucción en otro subproceso. | función SQLCancel |
Consulte también
referencia de LA API ODBC
archivos de encabezado ODBC
ejecución asincrónica (método de sondeo)