Função SQLConfigDriver
Conformidade
Versão introduzida: ODBC 2.5
Resumo
SQLConfigDriver carrega a DLL de configuração de driver apropriada e chama a função ConfigDriver .
A funcionalidade do SQLConfigDriver também pode ser acessada com ODBCCONF.EXE.
Sintaxe
BOOL SQLConfigDriver(
HWND hwndParent,
WORD fRequest,
LPCSTR lpszDriver,
LPCSTR lpszArgs,
LPSTR lpszMsg,
WORD cbMsgMax,
WORD * pcbMsgOut);
Argumentos
hwndParent
[Entrada] Identificador de janela pai. A função não exibirá nenhuma caixa de diálogo se o identificador for nulo.
fRequest
[Entrada] Tipo de solicitação.
fRequest deve conter um dos seguintes valores:
ODBC_CONFIG_DRIVER: altera o tempo limite de pool de conexões usado pelo driver.
ODBC_INSTALL_DRIVER: instala um novo driver.
ODBC_REMOVE_DRIVER: remove um driver existente.
Essa opção também pode ser específica do driver, caso em que o fRequest para a primeira opção deve começar do ODBC_CONFIG_DRIVER_MAX+1. A fRequest para qualquer opção adicional também deve começar com um valor maior que ODBC_CONFIG_DRIVER_MAX+1.
lpszDriver
[Entrada] O nome do driver conforme registrado nas informações do sistema.
lpszArgs
[Entrada] Uma cadeia de caracteres terminada em nulo que contém argumentos para um fRequest específico do driver.
lpszMsg
[Saída] Uma cadeia de caracteres terminada em nulo que contém uma mensagem de saída da configuração do driver.
cbMsgMax
[Entrada] Comprimento de lpszMsg.
pcbMsgOut
[Saída] Número total de bytes disponíveis para retornar em lpszMsg. Se o número de bytes disponíveis para retornar for maior ou igual a cbMsgMax, a mensagem de saída em lpszMsg será truncada para cbMsgMax menos o caractere de terminação nula. O argumento pcbMsgOut pode ser um ponteiro nulo.
Retornos
A função retornará TRUE se for bem-sucedida, FALSE se falhar.
Diagnósticos
Quando SQLConfigDriver retorna FALSE, um valor *pfErrorCode associado pode ser obtido chamando SQLInstallerError. A tabela a seguir lista os valores *pfErrorCode que podem ser retornados por SQLInstallerError e explica cada um deles no contexto dessa função.
*pfErrorCode | Erro | Descrição |
---|---|---|
ODBC_ERROR_GENERAL_ERR | Erro geral do instalador | Ocorreu um erro para o qual não houve nenhum erro específico do instalador. |
ODBC_ERROR_INVALID_BUFF_LEN | Comprimento do buffer inválido | O argumento lpszMsg era inválido. |
ODBC_ERROR_INVALID_HWND | Identificador de janela inválido | O argumento hwndParent era inválido. |
ODBC_ERROR_INVALID_REQUEST_TYPE | Tipo inválido de solicitação | O argumento fRequest não foi um dos seguintes: ODBC_INSTALL_DRIVER ODBC_REMOVE_DRIVER O argumento fRequest era uma opção específica do driver que era menor ou igual a ODBC_CONFIG_DRIVER_MAX. |
ODBC_ERROR_INVALID_NAME | Nome do driver ou tradutor inválido | O argumento lpszDriver era inválido. Não foi possível encontrá-lo no registro. |
ODBC_ERROR_INVALID_KEYWORD_VALUE | Pares de palavra-chave-valor inválidos | O argumento lpszArgs continha um erro de sintaxe. |
ODBC_ERROR_REQUEST_FAILED | Falha na solicitação | O instalador não pôde executar a operação solicitada pelo argumento fRequest . Falha na chamada para ConfigDriver . |
ODBC_ERROR_LOAD_LIBRARY_FAILED | Não foi possível carregar o driver ou a biblioteca de configuração do tradutor | Não foi possível carregar a biblioteca de configuração do driver. |
ODBC_ERROR_OUT_OF_MEM | Memória insuficiente | O instalador não pôde executar a função devido à falta de memória. |
Comentários
SQLConfigDriver permite que um aplicativo chame a rotina ConfigDriver de um driver sem precisar saber o nome e carregar a DLL de configuração específica do driver. Um programa de instalação chama essa função depois que a DLL de instalação do driver é instalada. O programa de chamada deve estar ciente de que essa função pode não estar disponível para todos os drivers. Nesse caso, o programa de chamada deve continuar sem erros.
Opções do Driver-Specific
Um aplicativo pode solicitar recursos específicos do driver expostos pelo driver usando o argumento fRequest . A fRequest para a primeira opção será ODBC_CONFIG_DRIVER_MAX+1 e opções adicionais serão incrementadas em 1 desse valor. Todos os argumentos exigidos pelo driver para essa função devem ser fornecidos em uma cadeia de caracteres terminada em nulo passada no argumento lpszArgs . Os drivers que fornecem essa funcionalidade devem manter uma tabela de opções específicas do driver. As opções devem estar totalmente documentadas na documentação do driver. Os gravadores de aplicativos que usam opções específicas do driver devem estar cientes de que esse uso tornará o aplicativo menos interoperável.
Definindo o tempo limite do pool de conexões
As propriedades de tempo limite do pool de conexões podem ser definidas quando você define a configuração do driver. SQLConfigDriver é chamado com um fRequest de ODBC_CONFIG_DRIVER e lpszArgs definidos como CPTimeout. CPTimeout determina o período de tempo em que uma conexão pode permanecer no pool de conexões sem ser usada. Quando o tempo limite expira, a conexão é fechada e removida do pool. O tempo limite padrão é de 60 segundos.
Quando SQLConfigDriver é chamado com fRequest definido como ODBC_INSTALL_DRIVER ou ODBC_REMOVE_DRIVER, o Gerenciador de Driver carrega a DLL de configuração de driver apropriada e chama a função ConfigDriver . Quando SQLConfigDriver é chamado com um fRequest de ODBC_CONFIG_DRIVER, todo o processamento é executado no instalador ODBC, para que a DLL de instalação do driver não precise ser carregada.
Mensagens
Uma rotina de configuração de driver pode enviar uma mensagem de texto para um aplicativo como cadeias de caracteres terminadas em nulo no buffer lpszMsg . A mensagem será truncada para cbMsgMax menos o caractere de terminação nula pela função ConfigDriver se for maior ou igual a caracteres cbMsgMax .
Funções relacionadas
Para obter informações sobre | Consulte |
---|---|
Adicionar, modificar ou remover um driver | ConfigDriver(na DLL de instalação) |
Removendo a fonte de dados padrão | SQLRemoveDefaultDataSource |