Partilhar via


Classe SqlErrorLogEvent

Aplica-se a: SQL Server

Fornece propriedades para exibir eventos em um arquivo de log do SQL Server especificado.

Sintaxe

class SQLErrorLogEvent
{
    stringFileName;
    stringInstanceName;
    datetimeLogDate;
    stringMessage;
    stringProcessInfo;
};

Propriedades

A classe SQLErrorLogEvent define as propriedades a seguir.

Propriedade Descrição
FileName Tipo de dados: string

Tipo de acesso: Somente leitura

O nome do arquivo do log de erros.
InstanceName Tipo de dados: string

Tipo de acesso: Somente leitura

Qualificadores: Key

O nome da instância do SQL Server em que o arquivo de log reside.
Data de registro Tipo de dados: datetime

Tipo de acesso: Somente leitura

Qualificadores: Key

A data e a hora em que o evento foi gravado no arquivo de log.
Mensagem Tipo de dados: string

Tipo de acesso: Somente leitura

A mensagem do evento.
Informações do processo Tipo de dados: string

Tipo de acesso: Somente leitura

Informações sobre a SPID (ID do processo do servidor de origem) do evento.

Comentários

Tipo Nome
MOF - sqlmgmprovider.mof (SQL Server 2022 (16.x) e versões posteriores)
- sqlmgmproviderxpsp2up.mof (SQL Server 2019 (15.x) e versões anteriores)
DLL sqlmgmprovider.dll
Namespace \root\Microsoft\SqlServer\ComputerManagement10

Exemplo

O exemplo a seguir mostra como recuperar valores para todos os eventos registrados em um arquivo de log especificado. Para executar o exemplo, substitua <Instance_Name> pelo nome da instância do SQL Server, como 'Instance1', e substitua 'File_Name' pelo nome do arquivo de log de erros, como 'ERRORLOG.1'.

on error resume next
strComputer = "."
Set objWMIService = GetObject("winmgmts:" _
    & "{impersonationLevel=impersonate}!\\" _
    & strComputer & "\root\MICROSOFT\SqlServer\ComputerManagement10")
set logEvents = objWmiService.ExecQuery("SELECT * FROM SqlErrorLogEvent WHERE InstanceName = '<Instance_Name>' AND FileName = 'File_Name'")
  
For Each logEvent in logEvents
WScript.Echo "Instance Name: " & logEvent.InstanceName & vbNewLine _
    & "Log Date: " & logEvent.LogDate & vbNewLine _
    & "Log File Name: " & logEvent.FileName & vbNewLine _
    & "Process Info: " & logEvent.ProcessInfo & vbNewLine _
    & "Message: " & logEvent.Message & vbNewLine _
  
Next

Comentários

Quando InstanceName ou FileName não são fornecidos na instrução WQL, a consulta retorna informações para a instância padrão e o arquivo de log atual do SQL Server. Por exemplo, a instrução WQL a seguir retorna todos os eventos de log do arquivo de log atual (ERRORLOG) na instância padrão (MSSQLSERVER).

"SELECT * FROM SqlErrorLogEvent"

Segurança

Para se conectar a um arquivo de log do SQL Server por meio do WMI, você deve ter as seguintes permissões nos computadores local e remoto:

  • Acesso de leitura ao namespace WMI Root\Microsoft\SqlServer\ComputerManagement10 . Por padrão, todos usuários têm acesso de leitura por meio da permissão Habilitar Conta.

  • Permissão de leitura para a pasta que contém os logs de erros. Por padrão, os logs de erros estão localizados no seguinte caminho (em que <Drive> representa a unidade em que você instalou o SQL Server e <InstanceName> é o nome da instância do SQL Server):

    <Unidade>:\Arquivos de Programas\Microsoft SQL Server\MSSQL13 .<InstanceName>\MSSQL\Log

Se você estiver se conectando por meio de um firewall, verifique se uma exceção está definida no firewall para WMI em computadores de destino remotos. Para obter mais informações, consulte Conectando-se ao WMI remotamente a partir do Windows Vista.

Confira também