IDENTITY je v SQL Server vlastnost atributu (sloupce), která umožňuje automatické číslování záznamů, které jsou vkládány do tabulky. Tuto vlastnost lze využít na číselné datové typy. Typické využítí je pro identifikátory a primární klíče. K automatickému číslování lze využít také jiných možností, např SEQUENCE.
Syntaxe IDENTITY
Identity připojujeme jako vlastnost sloupce např. při založení tabulky a příkaz má 2 argumenty:
IDENTITY (<počáteční hodnota>, <increment>)
- Počáteční hodnota – je hodnota od které se začíná číslovat. Typicky asi budeme chtít od 1, ale je možné číslovat od libovolného začátku
- Increment – je číslo o které se bude navyšovat
Příklad
Typické použití bude asi takové:
(1) Založení tabulky
CREATE TABLE [dbo].[Test_Identity] (
[ID] INT IDENTITY (1,1) PRIMARY KEY,
[Hodnota] VARCHAR(255) NOT NULL
);
(2) Vložení záznamů a kontrola očíslování – všimněte si, že vkládáme pouze hodnoty, nikoliv ID – to se čísluje samo
INSERT INTO [dbo].[Test_Identity] ([Hodnota])
VALUES ('Jedna'),('Dvě'),('Tři'),('Čtyři');
SELECT * FROM [dbo].[Test_Identity];
(3) Pokud nad tabulkou provedu TRUNCATE (vymazání hodnot) a tabulku znovu naplním, tak se mi záznamy znovu očíslují od 1 po 4. To je rozdíl oproti SEQUENCE, což je objekt, který si pamatuje poslední podanou hodnotu a vrátí hodnotu následující. V případě použítí SEQUENCE bychom dostali číslo 5-8 (nebo bysme museli sequenci resetovat.