classe de evento Exchange Spill
Aplica-se a: SQL Server Banco de Dados SQL do Azure Instância Gerenciada de SQL do Azure
A classe de evento Exchange Spill indica que os buffers de comunicação em um plano de consulta paralelo foram temporariamente gravados no banco de dados tempdb . Isso ocorre raramente e somente quando um plano de consulta tiver exames de vários intervalos.
Normalmente, a consulta Transact-SQL que gera essas verificações de intervalo tem muitos operadores BETWEEN, cada um dos quais seleciona um intervalo de linhas de uma tabela ou de um índice. Como alternativa, você pode obter vários intervalos usando expressões como (T.a > 10 AND T.a < 20) OR (T.a > 100 AND T.a < 120). Além disso, os planos de consulta devem exigir que esses intervalos sejam examinados em ordem, porque existe uma cláusula ORDER BY em T.a ou um iterador do plano requer que ele consuma as tuplas na ordem classificada.
Quando um plano de consulta para tal consulta tem vários operadores Parallelism , os buffers de comunicação de memória usados pelos operadores Parallelism ficam completos e pode surgir uma situação em que o progresso da execução da consulta é interrompido. Nessa situação, um dos operadores Parallelism grava seu buffer de saída em tempdb (uma operação chamada exchange spill) de modo que possa consumir linhas de alguns de seus buffers de entrada. Finalmente, as linhas derramadas são devolvidas ao consumidor quando este estiver pronto para consumi-las.
Muito raramente, vários exchange spills podem ocorrer no mesmo plano de execução, fazendo com que a execução da consulta seja lenta. Se você notar mais de cinco derramamentos na execução do mesmo plano de consulta, contate seu profissional de suporte.
Algumas vezes, os exchange spills são transitórios e podem desaparecer como alterações de distribuição de dados.
Há várias maneiras de evitar eventos de exchange spills:
Omita a cláusula ORDER BY se você não precisar que o conjunto de resultados seja ordenado.
Se ORDER BY for necessário, elimine a coluna que participa de vários exames de intervalo (T.a no exemplo acima) da cláusula ORDER BY.
Usando uma dica de índice, force o otimizador a usar um caminho de acesso diferente na tabela em questão.
Reescreva a consulta para produzir um plano de execução de consulta diferente.
Force a execução serial da consulta adicionando a opção MAXDOP = 1 no final da operação da consulta ou índice. Para obter mais informações, veja Configurar a opção max degree of parallelism de configuração de servidor e Configurar operações de índice paralelo.
Importante
Para determinar o local em que o evento Exchange Spill está ocorrendo quando o otimizador de consultas gera um plano de execução, também é necessário coletar uma classe de evento Showplan no rastreamento. É possível escolher qualquer uma das classes de evento Showplan, exceto as classes de evento Showplan Text e Showplan Text (Unencoded) , que não retornam a ID do nó. As ID do nó nos Showplans identificam cada operação que o otimizador de consultas executa ao gerar um plano de execução de consulta. Essas operações são chamadas operadores e cada operador no Showplan possui uma ID de nó. A coluna ObjectID dos eventos Exchange Spill corresponde à ID do nó nas classes de eventos Showplan. Assim, é possível determinar o operador ou a operação que gerou o erro.
Colunas de dados da classe de evento Exchange Spill
Nome da coluna de dados | Tipo de dados | Descrição | ID da coluna | Filtrável |
---|---|---|---|---|
ApplicationName | nvarchar | Nome do aplicativo cliente que criou a conexão com uma instância do SQL Server. Essa coluna é populada com os valores passados pelo aplicativo e não com o nome exibido do programa. | 10 | Sim |
ClientProcessID | int | ID atribuída pelo computador host ao processo em que o aplicativo cliente está sendo executado. Essa coluna de dados será populada se o cliente fornecer a ID de processo do cliente. | 9 | Sim |
DatabaseID | int | ID do banco de dados especificado pela instrução de banco de dados USE ou o banco de dados padrão se nenhuma instrução de banco de dados USE tiver sido emitida para uma determinada instância. O SQL Server Profiler exibirá o nome do banco de dados se a coluna de dados ServerName for capturada no rastreamento e o servidor estiver disponível. Determine o valor para um banco de dados usando a função DB_ID. | 3 | Sim |
DatabaseName | nvarchar | Nome do banco de dados no qual a instrução do usuário está sendo executada. | 35 | Sim |
EventClass | int | Tipo de evento = 127. | 27 | Não |
EventSequence | int | Sequência de um determinado evento na solicitação. | 51 | Não |
EventSubClass | int | Tipo de subclasse de evento. 1= Início do derramamento 2= Término do derramamento |
21 | Sim |
GroupID | int | ID do grupo de carga de trabalho no qual o evento de Rastreamento do SQL dispara. | 66 | Sim |
HostName | nvarchar | Nome do computador no qual o cliente está sendo executado. Essa coluna de dados será populada se o cliente fornecer o nome do host. Para determinar o nome do host, use a função HOST_NAME . | 8 | Sim |
IsSystem | int | Indica se o evento ocorreu em um processo do sistema ou do usuário. 1 = sistema, 0 = usuário. | 60 | Sim |
LoginName | nvarchar | Nome do logon do usuário (logon de segurança do SQL Server ou as credenciais de logon do Windows na forma de DOMAIN>\<username>).< | 11 | Sim |
LoginSid | imagem | Número SID (identificação de segurança) do usuário que fez logon. Você pode encontrar essas informações na tabela syslogins do banco de dados master . Cada SID é exclusivo para cada logon no servidor. | 41 | Sim |
NTDomainName | nvarchar | O domínio do Windows ao qual o usuário pertence. | 7 | Sim |
NTUserName | nvarchar | Nome do usuário do Windows. | 6 | Sim |
ObjectID | int | ID de objeto atribuída pelo sistema. Corresponde à ID do nó nos Showplans. | 22 | Sim |
RequestID | int | ID da solicitação que contém a instrução. | 49 | Sim |
ServerName | nvarchar | Nome da instância do SQL Server que está sendo rastreada. | 26 | Não |
SessionLoginName | nvarchar | Nome de logon do usuário que originou a sessão. Por exemplo, se você se conectar ao SQL Server usando Login1 e executar uma instrução como Login2, SessionLoginName mostrará Login1 e LoginName mostrará Login2. Esta coluna exibe logons do SQL Server e do Windows. | 64 | Sim |
SPID | int | Identificação da sessão em que ocorreu o evento. | 12 | Sim |
StartTime | datetime | Hora de início do evento, se disponível. | 14 | Sim |
TransactionID | bigint | ID da transação atribuída pelo sistema. | 4 | Sim |
XactSequence | bigint | Token que descreve a transação atual. | 50 | Sim |
Confira também
sp_trace_setevent (Transact-SQL)
Definir opções de índice
ALTER INDEX (Transact-SQL)