Tempová tabulka s hashtagem # nebo ## je dočasná tabulka, která je uložena v systémové databázi tempdb. Tabulka existuje pouze po dobu, po kterou je otevřena user session ID. Rozeznáváme 2 typy tempových tabulek:

  • Lokální # tempová tabulka – je přístupná pouze v rámci dané session, tzn vidí ji pouze uživatel vykonávající skript
  • Globální ## tempová tabulka – je přístupná z různých sessions, to znamená, že s ní mohou pracovat i ostatní uživatelé

Lokální # tempová tabulka

Lokální tempovou tabulku založíme jednoduše v rámci session 1:

SELECT 1 AS Number
INTO #Temp_table;

Lokální temp tabulka - ukázka

Pokud si otevřeme novou session (2) a spustíme dotaz na tuto tempovou tabulku, tak dostaneme chybuInvalid object name ‘#Temp_table’, protože temp tabulka je založena v session 1 a druhá session na ni nevidí

Lokální tempová tabulka - dotaz z jiné session - ukázka

Globální ## temp tabulka

V původní session 1 si založme pro změnu stejnou tabulku, ale tentokrát bude globální (##Temp_table):

Globální tempová tabulka - ukázka

Když se teď dotážeme na tabulku z jiné session, tak dostaneme výsledek, protože tentokrát na tabulku jiná session vidí:

Globální tempová tabulka - dotaz z jiné session - ukázka

5/5 - (3 votes)

Ing. Jan Zedníček - Data Engineer & Controlling

Jmenuji se Honza Zedníček a působím jako freelancer. Pracoval jsem dříve také jako BI developer, finanční controller a analytik. Vše pro společnosti z oblasti IT, bankovnictví, consultingu a výroby. Po práci si rád zahraju tenis, volejbal, šachy, zajdu do posilovny a občas neúspěšně odpálím pár balónků v golfu 🏌️

Již cca 10 let zapisuji na tento web různé návody určené zejména odborné veřejnosti, studentům a zájemcům o informace z oblastí Business intelligence, korporátních financí a reportingu.

🔥 Přihlašte se do naší Excel facebook skupiny (2.4k+ členů), kde si pomáháme Excel CZ/SK diskuse »

Leave a Reply

Your email address will not be published. Required fields are marked *