Global temporary tables in SQL Server

后端 未结 3 1850
灰色年华
灰色年华 2020-12-07 03:00

I have a ##table which can be accessed across all the sessions but sometimes I am getting error

There is already an object named \'##table\' in the

相关标签:
3条回答
  • 2020-12-07 03:07

    Found an interesting reference here:

    Global temporary tables operate much like local temporary tables; they are created in tempdb and cause less locking and logging than permanent tables. However, they are visible to all sessions, until the creating session goes out of scope (and the global ##temp table is no longer being referenced by other sessions). If two different sessions try the above code, if the first is still active, the second will receive the following:

    Server: Msg 2714, Level 16, State 6, Line 1 There is already an object named '##people' in the database.

    I have yet to see a valid justification for the use of a global ##temp table. If the data needs to persist to multiple users, then it makes much more sense, at least to me, to use a permanent table. You can make a global ##temp table slightly more permanent by creating it in an autostart procedure, but I still fail to see how this is advantageous over a permanent table. With a permanent table, you can deny permissions; you cannot deny users from a global ##temp table.

    0 讨论(0)
  • 2020-12-07 03:10
    There is already an object named '##table' in the database.
    

    You would typically get this error if you are doing a CREATE Table statement which would obviously fail as '##table' already exists in the database.

    Seems to me that maybe at some point in your code, the CREATE TABLE logic for this global table is being invoked again leading to this error.

    Do the have the details of the exact statement that results in this error?

    0 讨论(0)
  • 2020-12-07 03:22

    So the WHY part has been answered and here is how to resolve it:

    Do a check to see if the temp table exists before creating it:

        if object_id('tempdb..##table') is null begin
            --create table ##table...
        end
    

    I found a pretty interesting post about how to check the existence of a temp table from Googling http://sqlservercodebook.blogspot.com/2008/03/check-if-temporary-table-exists.html

    0 讨论(0)
提交回复
热议问题