日期:2014-05-17  浏览次数:20914 次

sql语句如何把统计函数 count做条件来用.
select   a.user_id,user_regTime,count(b.q_id)   as   num     from   VIEW_UserInfo   as   a   left   join   quoted   as   b   on     a.user_id=b.q_usernameid   and   q_sortid=21   group     by     a.user_id,user_regTime   order   by   user_regtime   desc

有这样一个sql语句现在我想把num字段作条件放在where   num> 10   里面不知道可行吗?   还有就是我还想把他放在order   by   num   desc里面排序   有什么好办法没啊。
直接把num当做普通字段来写不行啊。求高手指点。。

------解决方案--------------------
having count(b.q_id)> 1
------解决方案--------------------
会影响效率的,建议尽量不要用sql的复合语句
------解决方案--------------------
select a.user_id,user_regTime,count(b.q_id) as num from VIEW_UserInfo as a left join quoted as b on a.user_id=b.q_usernameid and q_sortid=21 group by a.user_id,user_regTime order by user_regtime desc,3 desc

order by 后面跟自然数,表示是以第几项字段进行排序,但无法使用聚合后的别名

聚合后的字段可以直接进行 where 判断,直接使用系统命名或别名都可以
------解决方案--------------------
having