Kuba707
14.06.2012, 22:00:17
Pytanie na szybko. Robię mini cmsa i w nim będzie tworzenie podstron. Chcę aby każda strona czyli rekord w bazie miała pole 'kolejnosc' - po to żebym w menu wyboru strony miał wypisane linki do wszystkich stron w bazie, ale posortowane według tego pola 'kolejnosc'.
I teraz kluczowe pytanie: Jak zrobić na poziomie bazy coś takiego, żeby podczas dodawania rekordu do bazy, pole 'kolejnosc' nowo dodawanego rekordu dostawało domyślnie wartość o 1 większą od najwyższej wartości w kolumnie 'kolejnosc' w tej tabeli?
CTRL
14.06.2012, 22:07:39
Auto increment powinien pomóc
Kuba707
14.06.2012, 22:23:23
No ok, ale jaki wybrać indeks? Bo dajmy na to mam teraz najwyższą wartość w tej kolumnie 15. Teraz nagle usuwam ten rekord gdzie akurat to pole kolejnosc jest 15, następnie dodaje nowy rekord i chcę by polu kolejnosc przypisało 15.
Age1869
14.06.2012, 22:26:06
auto increment w tym wypadku nic nie da. Zresztą nie wiem, czy da się to w ogóle zrobić z poziomu bazy. Do tego wystarczy zresztą raptem kilka prostych linijek php...
Niktoś
14.06.2012, 22:37:31
Tak da radę, ale wcale nie będzie to optymalne:
1.Usuwasz dane.
2.Selectem sprawdzasz ostatnie aktuale id;
3.Robisz truncate tabeli i ustalasz aktualne autoincrement od którego ma liczyć następne wiersze.
http://ariejan.net/2007/11/30/mysql-reset-...alue-of-a-table
Tuminure
14.06.2012, 22:44:22
Hmmm... albo mi się wydaje albo można zrobić to w taki sposób i będzie to (dostatecznie) optymalne.
Pisane i testowane w MySQL.
INSERT INTO `testowa`(`sort`)
VALUES ((SELECT MAX(`sort`)+1 FROM `testowa` AS `testy`))
Niktoś
14.06.2012, 23:42:48
Może i tak, ale nie w przypadku autoincrement.
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę
kliknij tutaj.