Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 6989523
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 27, 20262026-05-27T19:13:23+00:00 2026-05-27T19:13:23+00:00

How can I determine the space used by a table variable without using DATALENGTH

  • 0

How can I determine the space used by a table variable without using DATALENGTH on all columns?

eg:

DECLARE @T TABLE
(
a bigint,
b bigint,
c int,
d varchar(max)
)

insert into @T select 1,2,3, 'abc123'

exec sp_spaceused @T

Trying to work out how much memory a Table variable consumes when running a stored procedure.

I know in this example I can go:

SELECT DATALENGTH(a) + DATALENGTH(b) + DATALENGTH(c) + DATALENGTH(d)

But is there any other way other than doing DATALENGTH on all table columns?

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-27T19:13:24+00:00Added an answer on May 27, 2026 at 7:13 pm

    The metadata for table variables is pretty much the same as for other types of tables so you can determine space used by looking in various system views in tempdb.

    The main obstacle is that the table variable will be given an auto generated name such as #3D7E1B63 and I’m not sure if there is a straight forward way of determining its object_id.

    The code below uses the undocumented %%physloc%% function (requires SQL Server 2008+) to determine a data page belonging to the table variable then DBCC PAGE to get the associated object_id. It then executes code copied directly from the sp_spaceused procedure to return the results.

    DECLARE @T TABLE
    (
    a bigint,
    b bigint,
    c int,
    d varchar(max)
    )
    
    insert into @T select 1,2,3, 'abc123'
    DECLARE @DynSQL nvarchar(100)
    
    SELECT TOP (1) @DynSQL = 'DBCC PAGE(2,' + 
                           CAST(file_id AS VARCHAR) + ',' + 
                           CAST(page_id AS VARCHAR) + ',1) WITH TABLERESULTS' 
    FROM @T
    CROSS APPLY sys.fn_PhysLocCracker(%%physloc%%)
    
    
    DECLARE @DBCCPage TABLE (
        [ParentObject] [varchar](100) NULL,
        [Object] [varchar](100) NULL,
        [Field] [varchar](100) NULL,
        [VALUE] [varchar](100) NULL
    ) 
    INSERT INTO @DBCCPage
    EXEC (@DynSQL)
    
    DECLARE @id int
    
    SELECT @id = VALUE
    FROM @DBCCPage 
    WHERE Field = 'Metadata: ObjectId'
    
    
    
    EXEC sp_executesql N'
    USE tempdb
    
    declare @type character(2) -- The object type.  
      ,@pages bigint   -- Working variable for size calc.  
      ,@dbname sysname  
      ,@dbsize bigint  
      ,@logsize bigint  
      ,@reservedpages  bigint  
      ,@usedpages  bigint  
      ,@rowCount bigint  
    /*  
     ** Now calculate the summary data.   
     *  Note that LOB Data and Row-overflow Data are counted as Data Pages.  
     */  
     SELECT   
      @reservedpages = SUM (reserved_page_count),  
      @usedpages = SUM (used_page_count),  
      @pages = SUM (  
       CASE  
        WHEN (index_id < 2) THEN (in_row_data_page_count + lob_used_page_count + row_overflow_used_page_count)  
        ELSE lob_used_page_count + row_overflow_used_page_count  
       END  
       ),  
      @rowCount = SUM (  
       CASE  
        WHEN (index_id < 2) THEN row_count  
        ELSE 0  
       END  
       )  
     FROM sys.dm_db_partition_stats  
     WHERE object_id = @id;  
    
     /*  
     ** Check if table has XML Indexes or Fulltext Indexes which use internal tables tied to this table  
     */  
     IF (SELECT count(*) FROM sys.internal_tables WHERE parent_id = @id AND internal_type IN (202,204,211,212,213,214,215,216)) > 0   
     BEGIN  
      /*  
      **  Now calculate the summary data. Row counts in these internal tables don''t   
      **  contribute towards row count of original table.  
      */  
      SELECT   
       @reservedpages = @reservedpages + sum(reserved_page_count),  
       @usedpages = @usedpages + sum(used_page_count)  
      FROM sys.dm_db_partition_stats p, sys.internal_tables it  
      WHERE it.parent_id = @id AND it.internal_type IN (202,204,211,212,213,214,215,216) AND p.object_id = it.object_id;  
     END  
    
     SELECT   
      name = OBJECT_NAME (@id),  
      rows = convert (char(11), @rowCount),  
      reserved = LTRIM (STR (@reservedpages * 8, 15, 0) + '' KB''),  
      data = LTRIM (STR (@pages * 8, 15, 0) + '' KB''),  
      index_size = LTRIM (STR ((CASE WHEN @usedpages > @pages THEN (@usedpages - @pages) ELSE 0 END) * 8, 15, 0) + '' KB''),  
      unused = LTRIM (STR ((CASE WHEN @reservedpages > @usedpages THEN (@reservedpages - @usedpages) ELSE 0 END) * 8, 15, 0) + '' KB'')  
    
    
    ', N'@id int',@id=@id
    

    Returns

    name                           rows        reserved           data               index_size         unused
    ------------------------------ ----------- ------------------ ------------------ ------------------ ------------------
    #451F3D2B                      1           16 KB              8 KB               8 KB               0 KB
    
    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

How can I determine if my displays are in Clone Mode without using either
How can I determine all of the assemblies that my .NET desktop application has
Can somebody please let me know how we can determine if a local disk
Is there a way my program can determine when it's running on a Remote
I want to write a sh/bash script that can determine whether a particular directory
How can I determine the IP of my router/gateway in Java? I can get
How can you determine the performance consequences of your PHP code if you are
How can I determine if I have write permission on a remote machine in
How can I determine the name of the Bash script file inside the script
How can I determine if a Win32 thread has terminated? The documentation for GetExitCodeThread

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.