Hoe TEMP-tabel maken met behulp van een verklaring in SQL Server maken?

Hoe een temp-tabel te maken op dezelfde manier met het maken van een normale tabel?

Voorbeeld:

CREATE TABLE table_name 
(
    column1 datatype,
    column2 datatype,
    column3 datatype,
     ....
 );

Antwoord 1, Autoriteit 100%

Een tijdelijke tabel kan 3 soorten hebben, de #is het meest gebruikt. Dit is een temp-tabel die alleen in de huidige sessie bestaat.
Een equivalent hiervan is @, een gedeclareerde tabelvariabele. Dit heeft een beetje minder “functies” (zoals indexen enz.) En wordt ook alleen gebruikt voor de huidige sessie.
De ##is er een die hetzelfde is als de #, maar de reikwijdte is breder, zodat u deze binnen dezelfde sessie kunt gebruiken, binnen andere opgeslagen procedures.

U kunt op verschillende manieren een temp-tabel maken:

declare @table table (id int)
create table #table (id int)
create table ##table (id int)
select * into #table from xyz

Antwoord 2, Autoriteit 122%

hetzelfde, start de tabelnaam met #of ##:

CREATE TABLE #TemporaryTable          -- Local temporary table - starts with single #
(
    Col1 int,
    Col2 varchar(10)
    ....
);
CREATE TABLE ##GlobalTemporaryTable   -- Global temporary table - note it starts with ##.
(
    Col1 int,
    Col2 varchar(10)
    ....
);

Tijdelijke tabelnamen beginnen met #of ##– De eerste is een lokale tijdelijke tafel en de laatste is een wereldwijde tijdelijke tabel.

Hieris een van de vele artikelen die de verschillen tussen hen beschrijven.

Other episodes