SQLGetDiagField
Se aplica a: SQL Server Azure SQL Database Azure SQL Managed Instance Azure Synapse Analytics Analytics Platform System (PDW)
El controlador ODBC de SQL Server Native Client especifica los siguientes campos de diagnóstico adicionales para SQLGetDiagField. Estos campos admiten informes de errores enriquecidos para las aplicaciones de SQL Server y están disponibles en todos los registros de diagnóstico generados en los identificadores de conexión ODBC conectados y los identificadores de instrucciones ODBC. Los campos se definen en sqlncli.h.
Campo del registro de diagnóstico | Descripción |
---|---|
SQL_DIAG_SS_LINE | Indica el número de línea de un procedimiento almacenado que genera un error. El valor de SQL_DIAG_SS_LINE solamente es significativo si SQL_DIAG_SS_PROCNAME devuelve un valor. El valor se devuelve como un entero sin signo de 16 bits. |
SQL_DIAG_SS_MSGSTATE | El estado de un mensaje de error. Para obtener información sobre el estado del mensaje de error, vea RAISERROR. El valor se devuelve como un entero con signo de 32 bits. |
SQL_DIAG_SS_PROCNAME | Nombre del procedimiento almacenado que genera un error, si procede. El valor se devuelve como una cadena de caracteres. La longitud de la cadena (en caracteres) depende de la versión de SQL Server. Se puede determinar mediante una llamada a SQLGetInfo que solicita el valor para SQL_MAX_PROCEDURE_NAME_LEN. |
SQL_DIAG_SS_SEVERITY | El nivel de gravedad del mensaje de error asociado. El valor se devuelve como un entero con signo de 32 bits. |
SQL_DIAG_SS_SRVNAME | El nombre del servidor donde se ha producido el error. El valor se devuelve como una cadena de caracteres. La longitud de la cadena (en caracteres) se define en la macro SQL_MAX_SQLSERVERNAME de sqlncli.h. |
Los campos de diagnóstico específicos de SQL Server que contienen datos de caracteres, SQL_DIAG_SS_PROCNAME y SQL_DIAG_SS_SRVNAME, devuelven esos datos al cliente como cadenas terminadas en NULL, ANSI o Unicode. Si es necesario, el ancho de caracteres debe ajustar el recuento de caracteres. También se puede utilizar un tipo de datos de C portátil como TCHAR o SQLTCHAR para garantizar la longitud correcta de la variable de programa.
El controlador ODBC de SQL Server Native Client informa de los siguientes códigos de función dinámica adicionales que identifican la última instrucción de SQL Server que se intentó. El código de función dinámica se devuelve en el encabezado (registro 0) del conjunto de registros de diagnóstico y está por tanto disponible en cada ejecución (correcta o no).
Código de función dinámica | Source |
---|---|
SQL_DIAG_DFC_SS_ALTER_DATABASE | instrucción ALTER DATABASE |
SQL_DIAG_DFC_SS_CHECKPOINT | Instrucción CHECKPOINT |
SQL_DIAG_DFC_SS_CONDITION | Error surgido en las cláusulas WHERE o HAVING de una instrucción. |
SQL_DIAG_DFC_SS_CREATE_DATABASE | Instrucción CREATE DATABASE |
SQL_DIAG_DFC_SS_CREATE_DEFAULT | Instrucción CREATE DEFAULT |
SQL_DIAG_DFC_SS_CREATE_PROCEDURE | CREATE PROCEDURE, instrucción |
SQL_DIAG_DFC_SS_CREATE_RULE | Instrucción CREATE RULE |
SQL_DIAG_DFC_SS_CREATE_TRIGGER | CREATE TRIGGER, instrucción |
SQL_DIAG_DFC_SS_CURSOR_DECLARE | DECLARE CURSOR, instrucción |
SQL_DIAG_DFC_SS_CURSOR_OPEN | OPEN, instrucción |
SQL_DIAG_DFC_SS_CURSOR_FETCH | FETCH, instrucción |
SQL_DIAG_DFC_SS_CURSOR_CLOSE | Instrucción CLOSE |
SQL_DIAG_DFC_SS_DEALLOCATE_CURSOR | DEALLOCATE, instrucción |
SQL_DIAG_DFC_SS_DBCC | Instrucción DBCC |
SQL_DIAG_DFC_SS_DENY | DENY, instrucción |
SQL_DIAG_DFC_SS_DROP_DATABASE | DROP DATABASE, instrucción |
SQL_DIAG_DFC_SS_DROP_DEFAULT | Instrucción DROP DEFAULT |
SQL_DIAG_DFC_SS_DROP_PROCEDURE | Instrucción DROP PROCEDURE |
SQL_DIAG_DFC_SS_DROP_RULE | Instrucción DROP RULE |
SQL_DIAG_DFC_SS_DROP_TRIGGER | Instrucción DROP TRIGGER |
SQL_DIAG_DFC_SS_DUMP_DATABASE | Instrucción BACKUP o DUMP DATABASE |
SQL_DIAG_DFC_SS_DUMP_TABLE | Instrucción DUMP TABLE |
SQL_DIAG_DFC_SS_DUMP_TRANSACTION | Instrucción BACKUP o DUMP TRANSACTION. También se devuelve para una instrucción CHECKPOINT si la trunc. log en chkpt. la opción de base de datos está activada. |
SQL_DIAG_DFC_SS_GOTO | Instrucción GOTO de control de flujo |
SQL_DIAG_DFC_SS_INSERT_BULK | Instrucción INSERT BULK |
SQL_DIAG_DFC_SS_KILL | Instrucción KILL |
SQL_DIAG_DFC_SS_LOAD_DATABASE | Instrucción LOAD o RESTORE DATABASE |
SQL_DIAG_DFC_SS_LOAD_HEADERONLY | Instrucción LOAD o RESTORE HEADERONLY |
SQL_DIAG_DFC_SS_LOAD_TABLE | Instrucción LOAD TABLE |
SQL_DIAG_DFC_SS_LOAD_TRANSACTION | Instrucción LOAD o RESTORE TRANSACTION |
SQL_DIAG_DFC_SS_PRINT | PRINT, instrucción |
SQL_DIAG_DFC_SS_RAISERROR | RAISERROR, instrucción |
SQL_DIAG_DFC_SS_READTEXT | Instrucción READTEXT |
SQL_DIAG_DFC_SS_RECONFIGURE | Instrucción RECONFIGURE |
SQL_DIAG_DFC_SS_RETURN | Instrucción RETURN de control de flujo |
SQL_DIAG_DFC_SS_SELECT_INTO | Instrucción SELECT INTO |
SQL_DIAG_DFC_SS_SET | Instrucción SET (genérico, todas las opciones) |
SQL_DIAG_DFC_SS_SET_IDENTITY_INSERT | SET IDENTITY_INSERT, instrucción |
SQL_DIAG_DFC_SS_SET_ROW_COUNT | SET ROWCOUNT, instrucción |
SQL_DIAG_DFC_SS_SET_STATISTICS | Instrucción SET STATISTICS IO o SET STATISTICS TIME |
SQL_DIAG_DFC_SS_SET_TEXTSIZE | SET TEXTSIZE, instrucción |
SQL_DIAG_DFC_SS_SETUSER | SETUSER, instrucción |
SQL_DIAG_DFC_SS_SET_XCTLVL | Instrucción SET TRANSACTION ISOLATION LEVEL |
SQL_DIAG_DFC_SS_SHUTDOWN | Instrucción SHUTDOWN |
SQL_DIAG_DFC_SS_TRANS_BEGIN | Instrucción BEGIN TRAN |
SQL_DIAG_DFC_SS_TRANS_COMMIT | Instrucción COMMIT TRAN |
SQL_DIAG_DFC_SS_TRANS_PREPARE | Preparación para confirmar una transacción distribuida |
SQL_DIAG_DFC_SS_TRANS_ROLLBACK | Instrucción ROLLBACK TRAN |
SQL_DIAG_DFC_SS_TRANS_SAVE | Instrucción SAVE TRAN |
SQL_DIAG_DFC_SS_TRUNCATE_TABLE | TRUNCATE TABLE, instrucción |
SQL_DIAG_DFC_SS_UPDATE_STATISTICS | UPDATE STATISTICS, instrucción |
SQL_DIAG_DFC_SS_UPDATETEXT | instrucción UPDATETEXT |
SQL_DIAG_DFC_SS_USE | USE, instrucción |
SQL_DIAG_DFC_SS_WAITFOR | Instrucción WAITFOR de control de flujo |
SQL_DIAG_DFC_SS_WRITETEXT | Instrucción WRITETEXT |
SQLGetDiagField y parámetros con valores de tabla
SQLGetDiagField se puede usar para recuperar dos campos de diagnóstico: SQL_DIAG_SS_TABLE_COLUMN_NUMBER y SQL_DIAG_SS_TABLE_ROW_NUMBER. Estos campos ayudan a determinar qué valor produjo el error o la advertencia asociados al registro de diagnóstico.
Para obtener más información sobre los parámetros con valores de tabla, vea Parámetros con valores de tabla (ODBC).
Consulte también
Función SQLGetDiagField
Detalles de implementación de la API de ODBC