SQL IDENTITY (Auto increment) – Automatické zvýšení hodnoty, popis argumentů příkazu

Poslední aktualizace:

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];

IDENTITY-příklad

(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.

identity-po-truncate-table

 

 

SQL IDENTITY (Auto increment) – Automatické zvýšení hodnoty, popis argumentů příkazu
5 (100%) 1 vote[s]

Jmenuji se Honza Zedníček a nejčastěji se se mnou v civilu můžete potkat v kancelářích Kentico Software v Brně, kde působím jako BI Developer. Částečně pracuji také jako freelancer. Tuto práci dělám pro různé firmy již přes 5 let, ale Kentico je moje srdcovka ♡. Před tím jsem pracoval jako finanční controller třeba v Aero Vodochody a Sberbank nebo jako manažer dluhopisového programu v investiční skupině Unicapital. Po práci si rád zahraju tenis, volejbal, šachy, zajdu do posilovny a rád ochutnávám dobré rumy. Svoje znalosti se snažím zapisovat na tento web - abych je nezapomněl (působením rumu ^^) a sloužily i někomu dalšímu. Nebojte se položit dotaz nebo reagovat do komentáře. Přihlašte se do naší nové Excel facebook skupiny Excel CZ/SK diskuse »

Category: RSS 1 Exclude SQL příkazy Užitečné SQL skripty Tags:

About Ing. Jan Zedníček - BI Developer, Finance controller

Jmenuji se Honza Zedníček a nejčastěji se se mnou v civilu můžete potkat v kancelářích Kentico Software v Brně, kde působím jako BI Developer. Částečně pracuji také jako freelancer. Tuto práci dělám pro různé firmy již přes 5 let, ale Kentico je moje srdcovka ♡. Před tím jsem pracoval jako finanční controller třeba v Aero Vodochody a Sberbank nebo jako manažer dluhopisového programu v investiční skupině Unicapital. Po práci si rád zahraju tenis, volejbal, šachy, zajdu do posilovny a rád ochutnávám dobré rumy. Svoje znalosti se snažím zapisovat na tento web - abych je nezapomněl (působením rumu ^^) a sloužily i někomu dalšímu. Nebojte se položit dotaz nebo reagovat do komentáře. Přihlašte se do naší nové Excel facebook skupiny Excel CZ/SK diskuse »

Leave a Reply

Your email address will not be published.

This site uses Akismet to reduce spam. Learn how your comment data is processed.