Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: Pobieranie 2 rekordów dla każdego ID
Forum PHP.pl > Forum > Bazy danych > MySQL
Rysh
Chciałbym pobrać maksymalnie dwa posty każdego użytkownika:
  1. SELECT * FROM `posts` WHERE `posts`.`user_id` IN (1, 3, 4, 6, 8) AND `active` = 1

W tym przypadku pobiera mi wszystkie posty dla podanych ID użytkowników, a jak zrobić żeby ograniczyć wyniki tylko do dwóch dla każdego użytkownika ?
Rysh
Nie wiem czy mi się to przyda, w tym przypadku pobierasz dane z tabeli users a ja operuję na tabeli posts, bo tak mi generuje framework laravel:

  1. $users = User::orderBy('name')->with(['posts' => function($query) {
  2. return $query->where('active', '=', Post::VISIBLE);
  3. }])->paginate(5);
Puszy
A nie możesz tego napisać czystym SQL? Nie wiem jakie możliwości ma query builder w Laravelu ale bez subquery tego nie zrobisz, szczerze to nawet nie mam pojęcia jak miałbym to zrobić w Doctrinie korzystając z querybuildera. Wykonaj czysty SQL, będzie miał listę ID postów a następnie przekaż listę tych ID jako warunek do zwykłego pobierania w querybuilderze
Rysh
Cytat(Puszy @ 7.07.2017, 10:30:04 ) *
A nie możesz tego napisać czystym SQL? Nie wiem jakie możliwości ma query builder w Laravelu ale bez subquery tego nie zrobisz, szczerze to nawet nie mam pojęcia jak miałbym to zrobić w Doctrinie korzystając z querybuildera. Wykonaj czysty SQL, będzie miał listę ID postów a następnie przekaż listę tych ID jako warunek do zwykłego pobierania w querybuilderze

No właśnie myślałem, że może da się to jakoś zrobić, dlatego zapytałem smile.gif
Pokombinuje jeszcze trochę i jak nic nie wyjdzie zrobię w czystym SQL tak jak mówisz. A może przyjdzie jakaś inna mądra głowa i coś doradzi 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.