• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Zapisywanie id z bazy danych MySQL

+1 głos
98 wizyt
pytanie zadane 20 czerwca 2017 w PHP, Symfony, Zend przez BlvckFox Gaduła (3,420 p.)
Mam w bazie danych id zdjęcia, link do zdjęcia i opis zdjęcia. Chcialbym zeby uzytkownikowi tylko raz pojawiało się zdjęcie z bazy danych, więc muszę zrobić funkcje warunkową, która sprawdza, które zdjęcie już użytkownik widział i nie pokazywać tych, które już były - ale jak to zrobić, gdzie i w jakiej formie przechowywać ID widzianego obrazka?
W bazie MySQL przechowywanie id widzianego obrazka mija się trochę z celem. Cookies można usunąć. Co zrobić w takiej sytuacji?

3 odpowiedzi

+2 głosów
odpowiedź 20 czerwca 2017 przez Ehlert Mędrzec (165,080 p.)

Zrób sobie tabele id użytkownika z id zdjęcia.

Zgadzam się z kolegą. Dodaj jeszcze klucze obce z wymuszeniem integralności danych.

Przy 10 tysiącach zdjęć i dużej ilości użytkowników to duża ilość danych.

 Ta ilość danych to nic. Ludzie korzystają z relacji w bazach z tabelami po kilka giga.

Dodatkowo ciągła potrzeba bycia podłączonym do bazy danych.

A jak chcesz korzystać z bazy nie będąc podłączonym? 

komentarz 21 czerwca 2017 przez BlvckFox Gaduła (3,420 p.)

Więc całość powinna wyglądać tak?
 
Myśłałem nad tym na samym początku ale zrażała mnie myśl, że co chwilę będzie sprawdzało wszystkie id ale widzę, że optymalniej się tego raczej nie da zrobić. No to wracam do projektu, dzięki :)

komentarz 21 czerwca 2017 przez Ehlert Mędrzec (165,080 p.)

I pamiętaj. Korzystając z tej tabeli nie używaj podzapytań tylko kombinacji left join is null / is not null. 

+1 głos
odpowiedź 20 czerwca 2017 przez Michał Kazula Pasjonat (16,300 p.)
Zrób sobie tabele id użytkownika z id zdjęcia.
komentarz 20 czerwca 2017 przez BlvckFox Gaduła (3,420 p.)
Przy 10 tysiącach zdjęć i dużej ilości użytkowników to duża ilość danych. Dodatkowo ciągła potrzeba bycia podłączonym do bazy danych.
komentarz 20 czerwca 2017 przez Michał Kazula Pasjonat (16,300 p.)
Może opisz w jakim celu pokazujesz tez zdjęcia. To będzie lepiej Ci pomóc.

Jak na razie to nie widzę nic bardziej optymalnego niż tabela w bazie.
komentarz 20 czerwca 2017 przez BlvckFox Gaduła (3,420 p.)
Użytkownik wchodzi na pewną podstrone, widzi tam obrazek, opis obrazka i dwa buttony z napisami np. "Podoba mi się." i "Nie podoba mi się", po wciśnięciu na któryś z buttonów lub odświeżeniu obrazek zmienia się. W bazie danych przy obrazku będzie liczba kliknięć w "Podoba mi się" i "Nie podoba mi się".
komentarz 20 czerwca 2017 przez Michał Kazula Pasjonat (16,300 p.)
To jak nie chcesz zapisywać danych do bazy to dodaj guzik "Następny" albo "Już widziałem".

Jak masz dużą bazę zdjęć to możesz losować kolejność rekordów z bazy. Zawsze zmniejszasz prawdopodobieństwo ponownego pojawienia się tego samego zdjęcia.

 

Nadal twierdzę że tabela w bazie to najlepsze rozwiązanie.
2
komentarz 20 czerwca 2017 przez maciej.tokarz Nałogowiec (25,120 p.)
Skoro zapisujesz kliknięcia na podoba mi się i nie podoba to po co Ci jeszcze jakaś tabelka? Pokazujesz userowi tylko te zdjęcia, których nie ocenił.

M.
komentarz 21 czerwca 2017 przez BlvckFox Gaduła (3,420 p.)
To jest do zdjęcia ilość podoba mi się i nie podoba. Zapisuje tam liczbę +1 a nie id użytkowników którzy zagłosowali.
komentarz 21 czerwca 2017 przez maciej.tokarz Nałogowiec (25,120 p.)
Już Ci wspomnieli poprzednicy - filtrowanie rekordów nawet jak w tej tabelce będzie ich sto tysięcy nie jest niczym nadzwyczajnym. Kwestia założenia właściwie indeksów i ogółem zaprojektowania tabel.

M.
0 głosów
odpowiedź 20 czerwca 2017 przez Jedras Maniak (54,900 p.)
Zapisujesz do tabeli tylko zdjęcia, które widział user (id usera i id zdjecia) i przy wyświetlaniu zdjęcia sprawdzasz prostą instrukcją, które jeszcze zdjęcia możesz mu wyświetlić. Nie takie rzeczy w bazach się przechowywało i nie wydaje mi się żeby takie działanie było "złe". Po stronie klienta tego nie zrobisz.

Podobne pytania

0 głosów
1 odpowiedź 52 wizyt
0 głosów
1 odpowiedź 48 wizyt
0 głosów
2 odpowiedzi 121 wizyt
pytanie zadane 8 czerwca 2017 w C# i .NET przez liledusty Obywatel (1,430 p.)
Porady nie od parady
Pytania na temat serwisu SPOJ należy zadawać z odpowiednią kategorią dotyczącą tej strony.SPOJ

64,791 zapytań

111,250 odpowiedzi

233,951 komentarzy

46,683 pasjonatów

Przeglądających: 182
Pasjonatów: 9 Gości: 173

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto dwie polecane książki warte uwagi. Pełną listę znajdziesz tutaj.

...