SQL Server one query statement resulting in tempdb increasing by 55G (reprinted)

Source: Internet
Author: User

SQL Server One query statement causes tempdb to grow by 55G

Operating the server today, suddenly the lower right corner of the prompt "C disk space is insufficient"!

A fright! ~

Take a look at the C drive, and 7m!!!. How could this big C-disk space be gone? You can't wait for the server to move!

The first reaction might be a log problem, most likely a database log problem

So look at the log, are not big, normal.

DBCC sqlperf (LOGSPACE)

Check the system error:

Is the tempdb problem, but just looked at the log only a few m, as prompted to view the log status:

Select  from

Database journaling now has nothing to do, maybe it's done.

The active virtual log is also not many, 10 or so:

DBCC Loginfo

View current tempdb situation, surprise, tempdb data file 55g! Look at the graph above, which is a sudden increase.

So immediately shrink the log, shrink the data file, shrink out about 1G.

Or not, continue to constantly change the size of shrinking, as long as less than 55G are changed data to shrink, unexpectedly still can shrink 9g!

DBCC Shrinkfile (N'tempdev'1024x768)-- MBDBCC1024 ); -- units are MB

Temporarily relieved, seems to be unable to shrink. All said to restart the server is not the only line, the current connection is more, there is no restart. So first check out what caused the cause.

View current cursors, SQL, clogging, etc., nothing found, the transaction should be executed.

To view the allocation of tempdb records:

 UsetempdbGoSELECT Top Tent1.session_id, T1.internal_objects_alloc_page_count, T1.user_obje Cts_alloc_page_count,t1.internal_objects_dealloc_page_count, T1.user_objects_dealloc_page_count,t3.login_name, T3.status,t3.total_elapsed_time fromsys.dm_db_session_space_usage T1Inner JoinSys.dm_exec_sessions asT3 ont1.session_id=t3.session_idwhere(T1.internal_objects_alloc_page_count>0 orT1.user_objects_alloc_page_count>0orT1.internal_objects_dealloc_page_count>0 orT1.user_objects_dealloc_page_count>0)Order  byT1.internal_objects_alloc_page_countdesc

There are four key messages:

session_id: Wait until you can find information about the session

Internal_objects_alloc_page_count: The data page assigned to the inner object of the session

Internal_objects_dealloc_page_count: Data pages that have been released

Login_name: The logon name of the session

As can be seen from Internal_objects_alloc_page_count and Internal_objects_dealloc_page_count, the session was assigned 7236696 pages, calculated as follows:

Select 7236696*8/1024/1024 as [SIZE_GB]

55G, almost identical to the size of the tempdb growth, can be determined by this session. Internal_objects_dealloc_page_count can see that it has been released, and take up tempdb data has been released.

With the login name, you already know who is in action. (This is one of the benefits of giving each relevant person a sign-in name, which can be traced quickly to the user, internal to the operator)

Now look at the usefulness of this session_id:

Select p.*, S.text from cross apply Sys.dm_exec_sql_text ( P.sql_handle) swhere=1589

See finally there is a statement:

Copy out, almost the largest database of 8 tables do inner JOIN connection query !!

The code is not posted.

The problem of tempdb enlargement has been identified for some reason. tempdb shrinks from 55285MB to 47765MB, but the size of the problem is delayed restart the service is looking at.

SQL Server one query statement resulting in tempdb increasing by 55G (reprinted)

Contact Us

The content source of this page is from Internet, which doesn't represent Alibaba Cloud's opinion; products and services mentioned on that page don't have any relationship with Alibaba Cloud. If the content of the page makes you feel confusing, please write us an email, we will handle the problem within 5 days after receiving your email.

If you find any instances of plagiarism from the community, please send an email to: info-contact@alibabacloud.com and provide relevant evidence. A staff member will contact you within 5 working days.

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.