I'm asking this as a more general question on which will perform better.
I'm trying to get a set of comments and their score/rankings from two
tables.

*comments*
cid (integer, primary key)
title
body

*comment_ratings*
cid (integer, primary key)
uid (integer, primary key)
score

*Option 1* (Single group by query)
select c.cid,c.title,c.body,coalsece(sum(r.score),0) as score
from comments c left outer join comment_ratings r on c.cid = r.cid
group by c.cid,c.title,c.body;

*Option 2* (Two simple queries)
select cid,title,body from comments;
select cid,sum(score) from comment_ratings;

I know that in general you always want to keep the number of queries to a
minimum and that Option 1 is the most logical/preferred way to proceed.
However, I've greatly simplified Option 1.  In practice I'm going to be
pulling a lot more columns and will be inner joining to additional tables.
*So my real question is whether having a lot of items in the group by clause
will have an adverse effect on performance.*

Thanks in advance,
Jonathon

Reply via email to