문제

다음 종속 하위 쿼리를 자체 조인으로 변경하려면 어떻게해야합니까?

SELECT d.name, d.created,   
(SELECT SUM( q1.payout ) FROM client AS q1 WHERE q1.uid = d.uid) AS payout,   
(SELECT COUNT( q2.uid ) FROM client AS q2 WHERE q2.uid = d.uid AND q2.winning =1) AS cnt   
FROM client AS d group by d.name, d.created  ORDER BY cnt DESC   LIMIT 0 , 10; 
도움이 되었습니까?

해결책

SELECT  d.name, d.created, SUM(q1.payout) AS psum, COUNT(q2.uid) AS cnt
FROM    client d
LEFT JOIN
        client q1
ON      q1.uid = d.uid
LEFT JOIN
        client q2
ON      q2.uid = d.uid
        AND q2.winning =1
GROUP BY
        d.name, d.created
ORDER BY
        cnt DESC
LIMIT 0, 10

만약에 uid a PRIMARY KEY, 당신은 다음과 같이 다시 쓸 수 있습니다.

SELECT  d.name, d.created, SUM(payout) AS psum, COUNT(IF(winning = 1, uid, NULL)) AS cnt
FROM    client d
GROUP BY
        d.name, d.created
ORDER BY
        cnt DESC
LIMIT 0, 10

다른 팁

SELECT d.name, d.created, SUM(d.payout) AS allpayout, COUNT(alt.uid) as cnt
FROM client AS d
LEFT JOIN client AS alt
ON alt.uid = d.uid AND alt.winning = 1
GROUP BY d.name, d.created
ORDER BY cnt DESC
LIMIT 0, 10
SELECT d.name, d.created, SUM( d.payout ) AS payout, SUM( IF( d.winning = 1, 1, 0 ) ) AS cnt
FROM client AS d
GROUP BY
    d.name, d.created
ORDER BY cnt DESC   LIMIT 0 , 10;
라이센스 : CC-BY-SA ~와 함께 속성
제휴하지 않습니다 StackOverflow
scroll top