Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> Autonumeracja (licznik), zalezna od roku
SamoChwała
post
Post #1





Grupa: Zarejestrowani
Postów: 44
Pomógł: 0
Dołączył: 28.07.2004
Skąd: Łódź

Ostrzeżenie: (0%)
-----


Witam,

Jak mozna rozwiązć problem autonumeracji (licznika) pola np. ID zaleznego od roku, zachowując ciągłoś numerowania danego rocznika. Baza jest aktualizowana praktycznie na bieżąco, jedna zdarza się wstawiać rekord lub kilka z lat poprzednich. Do tej pory dane były zapisywane w osobnych tabelach, ale zaczyna to być uciążliwe.

Czy zechce mi ktoś pomóc!
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi
SamoChwała
post
Post #2





Grupa: Zarejestrowani
Postów: 44
Pomógł: 0
Dołączył: 28.07.2004
Skąd: Łódź

Ostrzeżenie: (0%)
-----


Obecnie wygląda to tak (wykaz tabel):
1. tab_2001 (id, data, opis, komentarz)
2. tab_2002 (id, data, opis, komentarz)
3. tab_2003 (id, data, opis, komentarz)
4. tab_2004 (id, data, opis, komentarz)

gdzie:

id - (AUTO_INCREMENT)
data - (date)
opis - (text)
komentarz - (text)

Chcę to trzymać w jednej tabeli. Probowałem sam coś napisać, ale bez rezultatu. Oczywiście pole id (AUTO_INCREMENT) zmieniłem na INT.

Obecnie jesli chcę dodać rekord z rocznika 2003 to muszę otwierać tabelę tab_2003 itd. Jest to dość uciążliwe przy dużej ilości danych (o pomyłkę w rocznikach nietrudno) gdyż ciągle muszę pamiętać o wybraniu prawidłowej tabeli.

Chcialbym by wyglądało to tak:
1. wpisuję date np. 12-05-2003
2. pojawia się komunikat (czy wprowadzona data jest prawidłowa)
3. potwierdzam (lub nie)
4. jesli potwierdziłem nadawany jest kolejny nr (id) dla danego rocznika zgodnego z datą
dla przykładu: (2001 ma id = 123; 2002 ma id = 76; 2003 ma id = 201) jeśli data będzie zawierała rok 2003 to po dodaniu id powinno otrzymać 202)
5. uzupełniam pozostałe dane
6. jeśli nie potwierdzę, pole daty jest czyszczone i ponownie dostępne do wprowadzenia poprawnej daty
Go to the top of the page
+Quote Post

Posty w temacie


Reply to this topicStart new topic
2 Użytkowników czyta ten temat (2 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 13.10.2025 - 19:47