Administração

Identificar qual query está enchendo o log do tempdb


Aprenda como Identificar qual query está enchendo o log do tempdb.

Para quem gostaria de identificar qual query está enchendo o log do tempdb abaixo colocarei algumas dicas:

Query:

;WITH tab AS (
 SELECT session_id,
 request_id,
 SUM(internal_objects_alloc_page_count) AS alloc_pages,
 SUM(internal_objects_dealloc_page_count) AS dealloc_pages
 FROM sys.dm_db_task_space_usage WITH (NOLOCK)
 WHERE session_id <> @@SPID
 GROUP BY session_id, request_id
)
SELECT TSU.session_id,
 TSU.alloc_pages * 1.0 / 128 AS [Espaço interno do objeto em MB],
 TSU.dealloc_pages * 1.0 / 128 AS [Espaço Interno do Objeto Desalocado em MB],
 EST.text,
 -- Extraindo o texto da Query
 ISNULL(
 NULLIF(
 SUBSTRING(
 EST.text,
 ERQ.statement_start_offset / 2, 
 CASE WHEN ERQ.statement_end_offset < ERQ.statement_start_offset 
 THEN 0 
 ELSE( ERQ.statement_end_offset - ERQ.statement_start_offset ) / 2 END
 ), ''
 ), EST.text
 ) AS [Texto da instrução],
 EQP.query_plan
FROM tab AS TSU
INNER JOIN sys.dm_exec_requests ERQ WITH (NOLOCK)
 ON TSU.session_id = ERQ.session_id
 AND TSU.request_id = ERQ.request_id
OUTER APPLY sys.dm_exec_sql_text(ERQ.sql_handle) AS EST
OUTER APPLY sys.dm_exec_query_plan(ERQ.plan_handle) AS EQP
WHERE EST.text IS NOT NULL OR EQP.query_plan IS NOT NULL
ORDER BY 3 DESC;

Aqui também vou colocar algumas dicas para minimizar esse crescimento.

1. Use poucas tabelas temporárias #tabela e tabelas variáveis @tabela
2. Minimize a manutenção de índices e evite ordenar índice no tempdb (SORT_IN_TEMPDB) se não for necessário.
3. Evite utilizar cursores, cursores estáticos usam work tables no tempdb.
4. Tente evitar spools
5. Evite triggers em operações de bulk
6. Não defina tempdb para ser o banco de dados padrão de todos.
7. Não use MARS.

Você também pode considerar que seu uso de log tempdb pode ser causado por processos internos que você tem pouco ou nenhum controle sobre eles – por exemplo, database mail, notificações de eventos, notificações de consulta e corretor de serviço todos usam tempdb de alguma forma. Você pode parar de usar esses recursos, mas se você estiver usando-os, você não pode ditar como e quando eles usam tempdb.

Identificar qual query está enchendo o log do tempdb
The following two tabs change content below.

Wesley Mota

DBA SQL Server
Profissional graduado em Banco de Dados e Sistemas de Informação com mais de 7 anos de experiência em empresas de software. Certificado MCSA Microsoft SQL Server possui intensa vivência em administração de banco de dados, Tunning, Performance SQL Server, levantamento de melhorias e monitoramento de banco de dados e servidores SQL Server. Consultoria SQL Server em diversos clientes no Brasil e ao redor do mundo. Escritor no blog dbasqlserverbr.com.br/blog. Onde compartilha conhecimento, experiências e dicas de performance para DBAs SQL Server. Conhecimentos em Oracle e ambientes de alta disponibilidade. Desenvolvimento de softwares web e mobile.Gerenciamento de equipe e projetos.

Latest posts by Wesley Mota (see all)

Wesley Mota

Profissional graduado em Banco de Dados e Sistemas de Informação com mais de 7 anos de experiência em empresas de software. Certificado MCSA Microsoft SQL Server possui intensa vivência em administração de banco de dados, Tunning, Performance SQL Server, levantamento de melhorias e monitoramento de banco de dados e servidores SQL Server. Consultoria SQL Server em diversos clientes no Brasil e ao redor do mundo. Escritor no blog dbasqlserverbr.com.br/blog. Onde compartilha conhecimento, experiências e dicas de performance para DBAs SQL Server. Conhecimentos em Oracle e ambientes de alta disponibilidade. Desenvolvimento de softwares web e mobile.Gerenciamento de equipe e projetos.

Share
Published by
Wesley Mota

Recent Posts

The Ultimate Guide to Gry Online Ruletka

If you are a fan of online gambling, then you must have come across gry…

1 semana ago

Discover the Adventures of Free Spins at Online Casino Sites

On the internet online casinos have transformed the betting industry, enabling players to vegas.hu online…

6 meses ago

Best Free Spins No Deposit

Casinos online offer free spins to draw new customers. These bonuses are usually very profitable,…

7 meses ago

Ideal Online Port Gambling Enterprises: An Overview to Locating the Perfect Pc Gaming Experience

In recent times, online casino sites have actually obtained enormous appeal among gamers, providing a…

7 meses ago

Best Online Casinos That Accept Bitcoin Down Payments

Bitcoin, the most preferred cryptocurrency worldwide, has reinvented lots of industries, including the on baixar…

7 meses ago

The Ultimate Guide to Online Slot Reviews

Online slots have turned into one of one of the most preferred forms of home…

7 meses ago