Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [MySQL][PHP] Ostatnio odwiedziłeś użytkownika - problem
Forum PHP.pl > Forum > Przedszkole
buddha
Cześć,

Kombinuje z przerobieniem funkcji która pokazuje użytkownikowi "kto cię ostatnio odwiedził"
na funkcje "ostatnio odwiedziłeś". jest to wykonalne edytując tą funkcje?

  1. function getMyVisitsUsers($uid) {
  2.  
  3. global $mysqli,$sm;
  4.  
  5. $search = '';
  6.  
  7. $count = $limit;
  8.  
  9. $time_now = time()-300;
  10.  
  11. $query2 = $mysqli->query("SELECT u2,timeago FROM users_visits where u1 = '$uid' and u2 <> '".$sm['user']['id']."' order by timeago desc limit 50");
  12.  
  13. $mysqli->query("UPDATE users_visits SET notification = 1 where u1 = '$uid'");
  14.  
  15. if($query2->num_rows > 0){
  16.  
  17. while($result2 = $query2->fetch_object()){
  18.  
  19. getUserInfo($result2->u2,6);
  20.  
  21. $time = $result2->timeago;
  22.  
  23. $search.='<li>
  24.  
  25. <a href="#" class="photo" data-back-photo="1" data-src="'.$sm['search']['profile_photo'].'" onClick="goToProfile('.$sm['search']['id'].')"></a>
  26.  
  27. </li>';
  28.  
  29. }
  30.  
  31. }
  32.  
  33.  
  34.  
  35. return $search;
  36.  
  37. }
markonix
Skoro masz w tabeli informacje o tym że Z odwiedzili X i Y to z prostej logiki też wiesz, że na liście odwiedzonych przez X jest między innymi Z...
Co do samej funkcji jest napisana beznadziejnie.
buddha
Czyli muszę zmienić tak?

  1. $query2 = $mysqli->query("SELECT u1,timeago FROM users_visits where u2 = '$uid' and u1 <> '".$sm['user']['id']."' order by timeago desc limit 50");
  2.  
  3. $mysqli->query("UPDATE users_visits SET notification = 1 where u2 = '$uid'");


Jestem kompletnie zielony. Uczę się na bieżąco przerabiając gotowca.
Niree
Nie znamy struktury bazy, nie wiadomo o co chodzi. Jak notujesz wizytę?
Rysh
Jeśli jesteś kompletnie zielony to może zleć to komuś kto się na tym zna?
Tomplus
Zamiast przerabiać poprawną funkcję, to stwórz nową, a potem użyć w miejsce gdzie istniała poprzednia.
Zamiast edytować/modyfikować tablicę w bazie, stwórz nową na potrzeby twojego małego projektu.

Jak coś popsujesz, to przynajmniej skutki będą mniej bolesne, a błędy bardziej widoczne.
buddha
@Tomplus masz racje, tylko problem tkwi w tym że nie potrafię napisać
prawidłowej funkcji.

Próbowałem już różnych modyfikacji kodu, niestety na dobre to nie wychodzi.
Tomplus
Wychodzi na to że masz braki w podstawach.

Ale przeanalizuj sobie co potrzebujesz aby stworzyć nową funkcjonalność?

Podpowiem, jeżeli chodzi o Ostatnio odwiedziłeś, to potrzebujesz informację:
- o uzytkowniku czyli $uid
- miejsca które ostatnio odwiedził

Nie znam struktury kodu strony, ale pewnie nie będzie problemu odczytać aktualną pozycję użytkownika (w razie czego pozostają wartości globalne _SERVER)

Potem tworzysz strukturę nowej tabeli:
uid, pageVisit, timeVisit

Potem tworzysz zapytanie MySQL gdzie zamiast UPDATE, tworzysz REPLACE, wtedy funkcja utworzy rekord gdy użytkownik jest pierwszy raz, a zastąpi go gdy taki rekord już istnieje - przyczym uid i pageVisit muszą być ustawione jako unikalne.
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.