Diskuze: Kontinuálne číslovanie záznamov v databáze
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.

Člen

Zobrazeno 10 zpráv z 10.
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
Udelal bych to možná triggerem, ze po smazani řádku projedeš všechny řádky az do konce a nastavis jim nove poradi. Pokud to chceš trochu optimalizovat, tak si v tom triggeru vzit cislo radku mazaneho radku a cislovani prenastavit az od dalšího řádku od aktualne smazaneho.
Ahoj, nie som C#ista, ale možno by bolo fájn napísať čo sa tým snažíš dosiahnuť? Je to dobrý pohľad na daný problém? Ak budeš mať v tabuľke milión záznamov a odstrániš prvý tak budeš chcieť ostatných 999 999 updatnúť?
Jsi si jistý, že to, co chceš udělat je správné? To, že po vymazání řádku už není to stejné ID již použito má svůj důvod. Představ si, že budeš mít někde navázaná data na tuto tabulku a vymažeš tu řádek. Dokážeš si představit, jaký vznikne chaos, když ty ID "přečísluješ"?
U databaze funguje count, pro cislovani radku vypsane tabulky podle zadanych pozadavku.
SELECT a, b, c, COUNt(*) as d FROM tabulka
Pokud ti jde o stanoveni poradi, treba v menu, to se bohuzel musi rucne.
Idealne pomocnou tabulkou, kde mas sloupce
(id_group, id_item, poradi) - group je skupina itemu, kterym nastavujes poradi,
coz se dela treba u podmenu u webove stranky, pokud to nechces mit serazene
default nebo podle abecedy.
DELETE * FROM tab_poradi
INSERT INTO ... (id_group, id_item, poradi) VALUES (1,3,1, 1,5,2) ...
Pokud to nedelas pres sql db, tak postup je podobny, jen si to musis vytvorit a obsluhovat sam.
DELETE * FROM tab_poradi WHERE id_group=1
To tam melo byt. Jakoze smazes vse, co spada do te skupiny, kde to potrebujes cislovat. takze to pak nemusis mazat po jednom. A ten insert se tez tusim pise trochu jinak, ale s googlem by to jiste nasel.
INSERT INTO ... (id_group, id_item, poradi) VALUES (1,3,1), (1,5,2) ...
A jeste mne napadlo, ze by bylo dobre, nepouzivat ajax pri kazde zmene polozky, ale nejdriv si to usporadat do js pole a pak najednou odeslat cele poradi. S ajaxem pri kazde zmene jsem to mel v jednom programu a strasne dlouho dela zmenu, kdyz mas vysokou zatez na server a potrebujes to preba 20x drag drop, jenom. Proste, se dlouho ceka, co ja treba nemam moc rad.
Pokud se jedná jen o zobrazení, tak kontinuální číslování zajistí metody konkrétního SQL serveru. Příklad pro MS SQL Server
select *,
ROW_NUMBER() OVER(ORDER BY idUser DESC) AS Row#
from users
Zobrazeno 10 zpráv z 10.