Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> Pomoc w zaprojektowaniu bazy
GeedieZ
post
Post #1





Grupa: Zarejestrowani
Postów: 12
Pomógł: 0
Dołączył: 21.02.2005

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


Prosiłbym o pomoc w zaprojektowaniu bazy ponieważ napotkałem problem i nie umiem sobie z nim poradzić:

Tabela tools:
Kod
tool_id   tool_name
1        Tool_1
2        Tool_2
3        Tool_3



Tabela parts:
Kod
part_id   part_name
1        Part_1
2        Part_2
3        Part_3


Teraz chodzi o to, by skonstruować jakąś tabelę łączącą te dwie tabele w taki sposób, że ukazywać będzie informacje typu:
Tool_1 składa się z:
2 części Part_1,
3 części Part_2,
0 części Part_3

Tool_2 składa się z:
1 części Part_1
2 części Part_2
3 części Part_3

itd...

Próbowałem zrobić tabelkę tools_parts_link, w której zawarłem takie informacje:
t_p_link_id matrix_id part1_id part1_qty part2_id part2_qty part3_id part3_qty part4_id part4_qty

Ale nic mi z tego nie wychodzi, poza tym jest to na pewno złe powiązanie z tabelą parts no ale brak mi już pomysłu jak to rozwiązać. Bardzo proszę o pomoc!

Ten post edytował GeedieZ 9.06.2008, 10:02:10
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi
pest
post
Post #2





Grupa: Zarejestrowani
Postów: 78
Pomógł: 15
Dołączył: 10.12.2007
Skąd: Lublin

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


Zrób tak
tabela 1
`tools` (id_tool, name, costam2)
tabela 2
`parts (id_part, costam, costam2)

tabela 3
`tool_parts` (id_tool, id_part, quantity)

i jak będziesz chciał wiedzieć z jakich części składa się tool1 to masz
  1. SELECT *
  2. FROM tools t, parts p, tool_parts tp
  3. WHERE t.id_tool = tp.id_tool AND tp.id_part = p.id_part AND t.name = $name

Wtedy masz kilka rekordów z ilością części i inną częścią w każdym rekordzie (oraz taką samą częścią).
Później możesz sobie to obrobić w PHP, albo pokombinować (bo można) jeszcze w MySQL, żeby zrobił podzapytanie o podzespoły i zwrócił 1 rekord z narzędziem i listą części.
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: 5.10.2025 - 07:37