Diskuze: automatické číslování ID sloupce v MSSQL
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.

Člen

Zobrazeno 7 zpráv z 7.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
Jak, resp. kde jsi to nastavil? A jak to do té tabulky vkládáš?
Měl bys na SQL mít nastaveno na sloupec AutoIncrement ->True a při
ukládání tento sloupec vůbec nezmiňovat, bo SQL server si to udělá
sám.
Další otázka je, jak víš, že si to čísluje jak chce? Nemáš to ve
výpisu jen špatně seřazené? Nemazal jsi náhodou nějakou položka a pak
nevkládal novou? V takovém případě SQL již nepoužije tu smazanou hodnotu
ID a pokračuje následujícím číslem...
Nastavoval jsem to ve vlastnostech daného sloupce. Do tabulky to vkládám pomocí dotazu v MSSQL, ptž jsem plnil databázi nějakými testovacími daty, sloupec ID samozřejmě vím že se naplní automatiky. To že vím že se mi to čísluje špatně vidím když se podívám v dané tabulce na edit.
když se podívám v dané tabulce na edit. Můžeš to nějak
upřesnit? Když si vypíšeš data z té tabulky, tak jsou špatně
číslovaná, nebo co? Hoď sem kus kódu, kterým to vypisuješ...
SQL v podstatě neumí špatně číslovat. Když si uložíš záznamy 1,2,3 a
třeba trojku smažeš a vložíš další záznam, tak má číslo 4, když pak
smažeš jedničku a vložíš další záznam, tak bude mít č.5
Ještě mě napadá jedna věc. Máš na sloupci ID nastaven primární
klíč? Primární klíč vytvoří clustrovaný index a díky tomu při
zobrazování záznamů bez ORDER BY se záznamy seřadí podle clustrovaného
indexu (data jsou fyzicky na disku uložena v pořadí tohoto indexu) tedy podle
vygenerovaných id-ček.
Pokud v tabulce nemáš clustered index, tak se ti záznamy nezobrazí
seřazené podle ID, takže to může vyvolávat dojem, že to přiděluje
čísla divně, ale není tomu tak.
Další možností je, že pokud selže vložení záznamu do db (díky
třeba nějaké constraint, duplicetě apod), tak se "vypotřebuje" jedno
ID-čko.
Např. poslední ID je 5, jeden insert selže, další vložení záznam má id
7...
Primární klíč mám na sloupci nastavený. Mě se to inkrementuje správně, ale nějaká tabulka začíná od id = 30 jiná zase třeba od 8.
Tak to spíš vidím na selhané INSERTy při testování (vyplýtvala se ID), nebo jestli jsi nějaké záznamy nejdřív nevložil a pak smazal... Jednou použitá ID se už nikdy znovu automaticky nepoužijí...
Zobrazeno 7 zpráv z 7.