Compartir vía


Función SQLConfigDriver

Conformidad
Versión introducida: ODBC 2.5

Resumen
SQLConfigDriver carga el archivo DLL de instalación del controlador adecuado y llama a la función ConfigDriver .

También se puede acceder a la funcionalidad de SQLConfigDriver con ODBCCONF.EXE.

Sintaxis

  
BOOL SQLConfigDriver(  
     HWND     hwndParent,  
     WORD     fRequest,  
     LPCSTR   lpszDriver,  
     LPCSTR   lpszArgs,  
     LPSTR    lpszMsg,  
     WORD     cbMsgMax,  
     WORD *   pcbMsgOut);  

Argumentos

hwndParent
[Entrada] Identificador de ventana principal. La función no mostrará ningún cuadro de diálogo si el identificador es NULL.

fRequest
[Entrada] Tipo de solicitud. fRequest debe contener uno de los siguientes valores:

ODBC_CONFIG_DRIVER: cambia el tiempo de espera de agrupación de conexiones usado por el controlador.

ODBC_INSTALL_DRIVER: instala un nuevo controlador.

ODBC_REMOVE_DRIVER: quita un controlador existente.

Esta opción también puede ser específica del controlador, en cuyo caso la fRequest de la primera opción debe comenzar desde ODBC_CONFIG_DRIVER_MAX+1. La fRequest para cualquier opción adicional también debe comenzar a partir de un valor mayor que ODBC_CONFIG_DRIVER_MAX+1.

lpszDriver
[Entrada] Nombre del controlador tal y como está registrado en la información del sistema.

lpszArgs
[Entrada] Cadena terminada en null que contiene argumentos para un fRequest específico del controlador.

lpszMsg
[Salida] Cadena terminada en null que contiene un mensaje de salida de la configuración del controlador.

cbMsgMax
[Entrada] Longitud de lpszMsg.

pcbMsgOut
[Salida] Número total de bytes disponibles para devolver en lpszMsg. Si el número de bytes disponibles para devolver es mayor o igual que cbMsgMax, el mensaje de salida de lpszMsg se trunca a cbMsgMax menos el carácter de terminación null. El argumento pcbMsgOut puede ser un puntero nulo.

Devoluciones

La función devuelve TRUE si se realiza correctamente, FALSE si se produce un error.

Diagnóstico

Cuando SQLConfigDriver devuelve FALSE, se puede obtener un valor *pfErrorCode asociado mediante una llamada a SQLInstallerError. En la tabla siguiente se enumeran los valores *pfErrorCode que SQLInstallerError puede devolver y explica cada uno de ellos en el contexto de esta función.

*pfErrorCode Error Descripción
ODBC_ERROR_GENERAL_ERR Error general del instalador Se produjo un error para el que no hubo ningún error de instalador específico.
ODBC_ERROR_INVALID_BUFF_LEN Longitud de búfer no válida El argumento lpszMsg no era válido.
ODBC_ERROR_INVALID_HWND Identificador de ventana no válido El argumento hwndParent no era válido.
ODBC_ERROR_INVALID_REQUEST_TYPE Tipo de solicitud no válido El argumento fRequest no era uno de los siguientes:

ODBC_INSTALL_DRIVER ODBC_REMOVE_DRIVER

El argumento fRequest era una opción específica del controlador que era menor o igual que ODBC_CONFIG_DRIVER_MAX.
ODBC_ERROR_INVALID_NAME Nombre de controlador o traductor no válido El argumento lpszDriver no era válido. No se encontró en el registro.
ODBC_ERROR_INVALID_KEYWORD_VALUE Pares de palabra clave-valor no válidos El argumento lpszArgs contenía un error de sintaxis.
ODBC_ERROR_REQUEST_FAILED Error de solicitud El instalador no pudo realizar la operación solicitada por el argumento fRequest . Error en la llamada a ConfigDriver .
ODBC_ERROR_LOAD_LIBRARY_FAILED No se pudo cargar el controlador ni la biblioteca de instalación del traductor No se pudo cargar la biblioteca de instalación del controlador.
ODBC_ERROR_OUT_OF_MEM No hay memoria suficiente El instalador no pudo realizar la función debido a una falta de memoria.

Comentarios

SQLConfigDriver permite a una aplicación llamar a la rutina ConfigDriver de un controlador sin tener que conocer el nombre y cargar el archivo DLL de instalación específico del controlador. Un programa de instalación llama a esta función después de instalar el archivo DLL de instalación del controlador. El programa de llamada debe tener en cuenta que es posible que esta función no esté disponible para todos los controladores. En tal caso, el programa de llamada debe continuar sin errores.

Opciones de Driver-Specific

Una aplicación puede solicitar características específicas del controlador expuestas por el controlador mediante el argumento fRequest . La fRequest de la primera opción será ODBC_CONFIG_DRIVER_MAX+1 y las opciones adicionales se incrementarán en 1 a partir de ese valor. Los argumentos requeridos por el controlador para esa función deben proporcionarse en una cadena terminada en null pasada en el argumento lpszArgs . Los controladores que proporcionan esta funcionalidad deben mantener una tabla de opciones específicas del controlador. Las opciones deben estar totalmente documentadas en la documentación del controlador. Los escritores de aplicaciones que usan opciones específicas del controlador deben tener en cuenta que este uso hará que la aplicación sea menos interoperable.

Establecer el tiempo de espera de agrupación de conexiones

Las propiedades de tiempo de espera de agrupación de conexiones se pueden establecer al establecer la configuración del controlador. Se llama a SQLConfigDriver con un fRequest de ODBC_CONFIG_DRIVER y lpszArgs establecido en CPTimeout. CPTimeout determina el período de tiempo que una conexión puede permanecer en el grupo de conexiones sin usarse. Cuando expira el tiempo de espera, la conexión se cierra y se quita del grupo. El tiempo de espera predeterminado es de 60 segundos.

Cuando se llama a SQLConfigDriver con fRequest establecido en ODBC_INSTALL_DRIVER o ODBC_REMOVE_DRIVER, el Administrador de controladores carga el archivo DLL de configuración del controlador adecuado y llama a la función ConfigDriver . Cuando se llama a SQLConfigDriver con un fRequest de ODBC_CONFIG_DRIVER, todo el procesamiento se realiza en el instalador ODBC, de modo que el archivo DLL de instalación del controlador no tenga que cargarse.

error de Hadoop

Una rutina de configuración del controlador puede enviar un mensaje de texto a una aplicación como cadenas terminadas en null en el búfer lpszMsg . El mensaje se truncará en cbMsgMax menos el carácter de terminación NULL por la función ConfigDriver si es mayor o igual que los caracteres cbMsgMax .

Para información acerca de Vea
Agregar, modificar o quitar un controlador ConfigDriver(en el archivo DLL de instalación)
Eliminación del origen de datos predeterminado SQLRemoveDefaultDataSource