Mysql
 sql >> Baza danych >  >> RDS >> Mysql

Pokaż trzy obrazy od każdego użytkownika

Nie wiem, czy istnieje lepsze rozwiązanie, ale myślę, że przydałoby się to:

SELECT p1.userID, p1.picture as pic1, p2.picture as pic2, p3.picture as pic3
FROM
  pictures p1 left join pictures p2
  on p1.userID=p2.userID and p1.picture<>p2.picture
  left join pictures p3
  on p1.userID=p3.userID and p1.picture<>p3.picture and p2.picture<>p3.picture
GROUP BY p1.userID

Spowoduje to wybranie trzech obrazów dla każdego użytkownika. Jeśli użytkownik ma mniej niż trzy obrazy, pokaże wartości null, jeśli ma więcej, wybierze trzy spośród nich wszystkich.

Alternatywą, która pokazuje trzy obrazy, każdy w innym wierszu, jest to zapytanie, które wykorzystuje zmienne:

SELECT userid, picture
FROM (
  SELECT
    userid,
    picture,
    case when @prec_id=userid then @row:[email protected]+1 else @row:=1 end as row,
    @prec_id:=userid
  FROM 
    `pictures`,
    (SELECT @prec_id:=0, @row:=0) s
  ORDER BY userid) s
WHERE row<=3

EDYTUJ: aby wyświetlić trzy obrazy dla każdego użytkownika naraz, użyłbym mojego pierwszego zapytania i zacząłbym od kodu takiego:

<?php
$mysqli = new mysqli("localhost", "username", "password", "test");

$image_path = "../images/";
$no_image = "../image/no_image.jpg";

if(!isset($_GET['first'])){
  $first = 0;
} else {
  $first = (int) $_GET['first'];
}

if ($stmt = $mysqli->prepare("SELECT p1.userID, p1.picture as pic1, p2.picture as pic2, p3.picture as pic3
FROM
  pictures p1 left join pictures p2
  on p1.userID=p2.userID and p1.picture<>p2.picture
  left join pictures p3
  on p1.userID=p3.userID and p1.picture<>p3.picture and p2.picture<>p3.picture
GROUP BY p1.userID
LIMIT ?,1")) {

    $stmt->bind_param("i", $first); 
    $stmt->execute();
    $stmt->bind_result($user, $pic1, $pic2, $pic3);
    $stmt->fetch();
    $stmt->close();
}
$mysqli->close();
?>
<div style="position:absolute; top:50px; left:100px; width:800px; text-align: center;">
  <img src="<?PHP echo (isset($pic1) ? $image_path.$pic1 : $no_image); ?>" width="176px" height="197px">
  <img src="<?PHP echo (isset($pic2) ? $image_path.$pic2 : $no_image); ?>" width="176px" height="197px">
  <img src="<?PHP echo (isset($pic3) ? $image_path.$pic3 : $no_image); ?>" width="176px" height="197px">
</div>

(zostało ulepszone, ale możesz zacząć od tego. Używam mysqli zamiast mysql)




  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Zabezpieczanie serwera MySQL

  2. Django :Tabela nie istnieje

  3. Pobieranie danych z MySQL w partiach za pomocą Pythona

  4. Zmiana zapytania SQL z jednego warunku na kilka

  5. Dopasowanie ciągu zapytania MySQL SELECT