Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: Problem koncepcyjny
Forum PHP.pl > Forum > Bazy danych > MySQL
Lysiur
Witam, mam pewien problem z zaprojektowaniem pewnego problemu.

mam tabelę:

person | id_person, firstName, .... | Jest to tabela zbiorcza w całym systemie CRM, ponieważ w niej przechowuje wszystkie osoby w systemie (prawcownicy, klienci, opiekunowie, płatnicy, kontrahenci, etc...)

część z typów, ma swoje specyficzne dane, np.:

person_opiekun | id_person, id_parent | id_parent wskazuje na tabelę person_worker.

Problem mam taki, ponieważ opiekunowie posiadają swoje zgłoszenia. Zgłoszenie posiada bardzo wiele danych i mam problem z koncepcją ich utrwalenia. Część formularza opiekuna posiada pola wielokrotnego wyboru (checkboxy), jednokrotnego (radio), no i pola tekstowe. Dodatkowo każdy opiekun może posiadać tylko jedno zgłoszenie.

Np.: mam pole w formularzu zainteresowania:
[ ] koty,
[ ] psy,
[ ] skorpiony
etc.

Tego typu pól (wielokrotnego wyboru) jest około 12.

Aktualnie mam to rozwiązane na zasadzie tabeli:

opiekun_questionnaire | id_person (uchwyt do person_opiekun | hobby_koty | hobby_psy | hobby_skorpiony, .... | I jeśli ktoś wybrał opcje ustawiam 1, w przeciwnym razie 0.

Problem jest taki, że po wszystkich polach z zgłoszenia muszę filtrować dane, w zależności co jest potrzebne. Obecne rozwiązanie działa dobrze, ale zastanawiam się czy można to zrobić jakoś lepiej.






nospor
Tabela ZAINTERESOWANIA (tutaj beda twoje koty, psy...):
ID
NAME

Tabela PERSON
ID
NAME

Tabela KWESTIONARIUSZ
ID
ID_PERSON - osoba, ktora wypelniala

TABELA KWESTIONARIUSZ_ZAINTERESOWANIA (tabela laczaca kwestionariusz z danymi zainteresowaniami)
ID_KWESTIONARIUSZ
ID_ZAINTERESOWANIA
Lysiur
Dzięki za odpowiedź, jakiś czas temu rozważałem takie podejście, jednak może być problem z pobraniem całego zgłoszenia, ponieważ będę musiał łączyć kilka-kilkanaście tabel. I zastanawiam się czy nie będzie zbyt dużo problemów z wyszukiwaniem po tego typu polach
nospor
Sposób jaki ci podałem, tak właśnie robi się tego typu relacje.
Wyszukiwanie nie powinno być problemem,nie raz tak robiłem i szukałem.

W podejsciu co ty proponujesz to: masz niesamowicie dużą tabele (dużo kolumn). Wiele z tych kolumn będzie nie wykorzystanych z przypadku, gdy ktoś nie zaznaczy danej opcji. By wyszukiwanie było optymalne, będziesz musiał tworzyć indeksy na każdą z kolumn, lub nawet na kombinacje kolumn. Gdy dojdzie jakaś opcja, będziesz musiał dodawać kolumny. Same minusy smile.gif
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.
Invision Power Board © 2001-2025 Invision Power Services, Inc.