Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [CakePHP] relacje
kicaj
post
Post #1





Grupa: Zarejestrowani
Postów: 1 640
Pomógł: 28
Dołączył: 13.02.2003
Skąd: Międzyrzecz/Poznań

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


Probuje stworzyc relacje w ten sposob:
Kod
Article hasOne User
User hasMany Article
User hasMany Comments
Articles hasMany Comments


Tabela 'comments' chcialbym zeby wygladala mniej wiecej tak:
Kod
id
content
user_id
model
foreign_key
...


Przykladowe wiersze w tabeli 'comments':
Kod
1, 'Witaj kolego!' 123, User, 3        // user_id=123 dodal komentarz do uzytkownika o id=3
2, 'Dobry artykul!', 234, Article, 42    // user_id=234 dodal komentarz do artykulu o id=42


Czy to jest dobry sposob dla tabeli 'comments', dobre rozumowanie.
I w jaki sposob mialby dzialac model Comment?

Ten post edytował kicaj 10.01.2009, 02:30:52
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi
Rafal Filipek
post
Post #2





Grupa: Zarejestrowani
Postów: 274
Pomógł: 54
Dołączył: 2.05.2006
Skąd: Nadarzyn

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


oczywiscie mozna wrzucic wszystkie komentarze do jednej tabeli ale nie wiem czy ma to sens. raz ze mieszasz ze soba rozne komentarze ( jakby nie bylo jedne dotyczna tekstow a inne uzytkownikow ) a 2 ze moze ci sie tego zrobic strasznie duzo w tabeli. Skoro masz komentarze dla uzytkownikow i tekstow to zrob 2 tabele users_comments i articles_comments i wtedy nie ma problemu bo robisz sobie najprostrze relacje. do tego nie bedziesz mial problemu jezeli bedziesz chcial wyciagnac np. jednoczesnie 10 ostatnich komentarzy dla uzytkownika i 10 ostatnich komentarzy dla jego tekstow czy cos w tym stylu. czasami jest lepiej zrobic 1 dodatkowa tabele 1 dodatkowy model z ktorym i tak nigdy nie bedziesz mial problemu a zawsze bedziesz mial mozliwosc jakiejs modyfikacji.
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: 27.12.2025 - 14:43