SQL сложный составной запрос

Помогите составить sql запрос (php + mysql).
Есть три таблицы:
1. материалы (material): id, id_user;
2. пользователи (user): id;
3. лайки (likes): id, id_material, count_like ;
В таблице материалов хранятся статьи пользователей. У каждой статьи есть количество лайков, которое хранится в таблице лайки в поле count. id_material в таблице лайков уникален.

Нужно составить запрос, который бы считал общее количество лайков у материалов конкретного пользователя, зная его id.
Можно конечно сделать это несколькими запросами с php:
/** * GeSHi (C) 2004 - 2007 Nigel McNie, 2007 - 2008 Benny Baumann * (http://qbnz.com/highlighter/ and http://geshi.org/) */ .php.geshi_code {font-family:monospace;} .php.geshi_code .imp {font-weight: bold; color: red;} .php.geshi_code .kw1 {color: #b1b100;} .php.geshi_code .kw2 {color: #000000; font-weight: bold;} .php.geshi_code .kw3 {color: #990000;} .php.geshi_code .co1 {color: #666666; font-style: italic;} .php.geshi_code .co2 {color: #666666; font-style: italic;} .php.geshi_code .co3 {color: #0000cc; font-style: italic;} .php.geshi_code .co4 {color: #009933; font-style: italic;} .php.geshi_code .coMULTI {color: #666666; font-style: italic;} .php.geshi_code .es0 {color: #000099; font-weight: bold;} .php.geshi_code .es1 {color: #000099; font-weight: bold;} .php.geshi_code .es2 {color: #660099; font-weight: bold;} .php.geshi_code .es3 {color: #660099; font-weight: bold;} .php.geshi_code .es4 {color: #006699; font-weight: bold;} .php.geshi_code .es5 {color: #006699; font-weight: bold; font-style: italic;} .php.geshi_code .es6 {color: #009933; font-weight: bold;} .php.geshi_code .es_h {color: #000099; font-weight: bold;} .php.geshi_code .br0 {color: #009900;} .php.geshi_code .sy0 {color: #339933;} .php.geshi_code .sy1 {color: #000000; font-weight: bold;} .php.geshi_code .st0 {color: #0000ff;} .php.geshi_code .st_h {color: #0000ff;} .php.geshi_code .nu0 {color: #cc66cc;} .php.geshi_code .nu8 {color: #208080;} .php.geshi_code .nu12 {color: #208080;} .php.geshi_code .nu19 {color:#800080;} .php.geshi_code .me1 {color: #004000;} .php.geshi_code .me2 {color: #004000;} .php.geshi_code .re0 {color: #000088;} .php.geshi_code span.xtra { display:block; }

$sum=0;
$sel_material=$mysqli->query('SELECT id FROM material WHERE id_user=3');
while ($row=$sel_material->fetch_assoc()) {
   $sel_like=$mysqli->query('SELECT count_like FROM likes WHERE id_material='$row["id"]' LIMIT 1);
   $count_like=$sel_like->fetch_assoc();
   $sum+=$count_like["count_like"];
}
return $sum;

Возможно ли это сделать одним запросом? Или как максимально оптимизировать эту задачу.

1 ответов


С join-ом получше будет:


select sum(count_like) as count_like
from likes
  join material
  on likes.id_material = material.id
  and material.id_user = 3
 

Это, по-вашему, сложный запрос?


SELECT COUNT(1) FROM likes WHERE id_material in (SELECT id FROM material WHERE id_user=...)
 
Или у вас id пользователя мучительно ищется по таблице user с одним столбцом?