Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [MySQL] Tworzenie tabeli, primary key i inne
Capellini
post 14.06.2009, 13:02:35
Post #1





Grupa: Zarejestrowani
Postów: 70
Pomógł: 0
Dołączył: 16.10.2007

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


Nie jestem zbyt doświadczony jeżeli chodzi o MySQL dlatego proszę Was o radę. Chciałbym stworzyć tabelę, w której będą przechowywane dane na temat graczy w pewną grę. Tabela ta będzie miała 4 albo 5 pól:
-> ID gracza,
-> nazwa gracza,
-> hasło gracza,
-> wynik gracza,
-> ew. miejsce gracza w rankingu.

Zastanawiam się, któremu z tych pól mam ustawić Primary Key. Chyba powinno być to ID, ale chciałbym żebym mógł także szybko odszukiwać graczy o najwyższych wynikach więc chciałbym, żeby ci gracze byli posortowani jakoś wg miejsca w rankingu. I jeszcze jedno pytanie - czy można jakoś ustawić tak, żeby pole określające miejsce gracza w rankingu automatycznie ustawiało się wg wyniku, tzn. żebym przy zmianie wyniku jakiegoś gracza, nie musiał zmieniać miejsca w rankingu danego gracza?

Ten post edytował Capellini 14.06.2009, 13:02:47


--------------------
WIELKIE DZIĘKI ZA POMOC!
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi (1 - 6)
Spawnm
post 14.06.2009, 13:06:20
Post #2





Grupa: Moderatorzy
Postów: 4 069
Pomógł: 497
Dołączył: 11.05.2007
Skąd: Warszawa




kolejność ustalisz przy wywoływaniu z bazy na pomocą ORDER BY cos DESC ew ASC
id nic do tego nie ma.
a jako key daj:
->ID gracza,
-> nazwa gracza,
-> hasło gracza,

bo to są pola obowiązkowe smile.gif
Go to the top of the page
+Quote Post
Capellini
post 14.06.2009, 13:19:50
Post #3





Grupa: Zarejestrowani
Postów: 70
Pomógł: 0
Dołączył: 16.10.2007

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


Cytat
kolejność ustalisz przy wywoływaniu z bazy na pomocą ORDER BY cos DESC ew ASC


W takim razie pole Miejsce można by wyrzucić, ale potrzebuję jeszcze, żeby można było szybko określić miejsce gracza mając ID gracza więc musi zostać, tylko że tutaj pojawia się jeszcze jeden problem z tym miejscem. Gdy dodaję nowego gracza, to wcale nie musi on od razu być na ostatnim miejscu, bo jest możliwe, że inni gracze mają wynik ujemny i wtedy musiałbym powiększać o 1, miejsce w rankingu każdemu, co jest pod tym nowym. Czy jest jakieś inne wyjście niż to powiększanie każdemu miejsca o 1?

Cytat
a jako key daj:
->ID gracza,
-> nazwa gracza,
-> hasło gracza,

bo to są pola obowiązkowe


Czyli primary key ustawia się polom, które są obowiązkowe? Właściwie to pole wynik i miejsce też są obowiązkowe więc też mam im ustawić primary key?

Ten post edytował Capellini 14.06.2009, 13:21:40


--------------------
WIELKIE DZIĘKI ZA POMOC!
Go to the top of the page
+Quote Post
Spawnm
post 14.06.2009, 13:30:19
Post #4





Grupa: Moderatorzy
Postów: 4 069
Pomógł: 497
Dołączył: 11.05.2007
Skąd: Warszawa




od kiedy to może być tylko jeden?
może być kilka, oddziela się je przecinkiem przy tworzeniu np:
  1. CREATE TABLE `test1` (
  2. contact_id INT(10),
  3. name VARCHAR(40),
  4. birthdate DATE,
  5. PRIMARY KEY (contact_id,name)
  6. );
Go to the top of the page
+Quote Post
Fifi209
post 14.06.2009, 13:31:52
Post #5





Grupa: Zarejestrowani
Postów: 4 655
Pomógł: 556
Dołączył: 17.03.2009
Skąd: Katowice

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


Cytat(Spawnm @ 14.06.2009, 14:30:19 ) *
od kiedy to może być tylko jeden?
może być kilka, oddziela się je przecinkiem przy tworzeniu np:
  1. CREATE TABLE `test1` (
  2. contact_id INT(10),
  3. name VARCHAR(40),
  4. birthdate DATE,
  5. PRIMARY KEY (contact_id,name)
  6. );


Fakt, zakręciłem się.


--------------------
Zainteresowania: C#, PHP, JS, SQL, AJAX, XML, C dla AVR
Chętnie pomogę, lecz zanim napiszesz: Wujek Google , Manual PHP
Go to the top of the page
+Quote Post
Capellini
post 14.06.2009, 13:39:38
Post #6





Grupa: Zarejestrowani
Postów: 70
Pomógł: 0
Dołączył: 16.10.2007

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


A jak rozwiązać ten problem z ustalaniem miejsc przy dodawaniu nowego gracza? Problem polega na tym, że nowy gracz wcale nie zaczyna z najgorszym wynikiem i nie znajduje się wcale na najniższym miejscu. Więc po pierwsze jest problem z ustaleniem miejsca tego nowego gracza, bo nie widzę innego sposobu niż policzyć, ile jest po prostu osób z wyższym wynikiem od nowego gracza, a po drugie jest taki problem, że tym wszystkim, którzy mają gorszy wynik od nowego gracza trzeba przestawić miejsce o jedno niżej.


--------------------
WIELKIE DZIĘKI ZA POMOC!
Go to the top of the page
+Quote Post
Crozin
post 14.06.2009, 13:50:04
Post #7





Grupa: Zarejestrowani
Postów: 6 476
Pomógł: 1306
Dołączył: 6.08.2006
Skąd: Kraków

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


Dla kolumny id ustaw PRIMARY KEY.
Dla kolumny nazwa_gracza możesz dodać UNIQUE KEY

Powiedz mi jeszcze czy dobrze rozumiem kolumny wynik oraz ranking. Wynik, to wartość zdobytych punktów, a ranking to pozycja gracza na liście najlepszych wyników, czyli przykładowo:
Kod
+-------+---------+
| wynik | ranking |
+-------+---------+
|   123 |       1 |
|   110 |       2 |
|    76 |       3 |
|    75 |       4 |
|    50 |       5 |
+-------+---------+
Dobrze by było abyś w bazie danych przechowywał zarówno wynik jak i ranking użytkownika. Ranking co prawda można by każdorazowo dynamicznie obliczać, ale to niepotrzebny wysiłek dla bazy. I teraz jeżeli chodzi o nadawanie indeksów (teraz to już będzie zwykły indeks, nie primary czy unique). Jeżeli masz zamiar przeszukiwać tabelę na podstawie kolumny wynik to dla niej zakładasz indeks. Jeżeli masz zamiar przeszukiwać ją na podstawie kolumny ranking to dla niej też zakładasz index.
Go to the top of the page
+Quote Post

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

 



RSS Wersja Lo-Fi Aktualny czas: 14.08.2025 - 01:48