2、使用字符串来代替T和0,如“TRUE”和“FALSE”,这样就可以避免T和0的混淆。
3、使用自定义的数值来代替T和0,如1和2,这样也能够避免混淆。
4、使用布尔类型,如BIT类型或者BOOL类型,这样就可以避免使用T和0。
5、使用ENUM类型来代替T和0,ENUM类型可以设置多个可选值,这样也可以避免T和0的混淆。
SELECTa.update_date,
a.user_id,
a.news_id,
(CASE WHEN b.counter IS NULL THEN 0 ELSE b.counter END) as 'Counter'
FROM (
SELECT update_date, user_id, news_id
FROM t_comment
GROUP BY update_date, user_id, news_id) a
LEFT OUTER JOIN
(
SELECT update_date, user_id, news_id,
count(*) AS counter FROM t_comment
WHERE user_id = 2 AND news_id = 15
GROUP BY user_id, news_id
) b
ON a.update_date = b.update_date
AND a.user_id = b.user_id
AND a.news_id = b.news_id
GO
T-SQL实现,原理如上,未经测试。祝你好运。
语句大概是这样的select A.ID ,count(B.ID)from A left join B on A.ID=B.IDgroup by B.ID order by
count(B.ID) desc
没有亲自试验,可能不对,但根据你这个问题,大致思路就是这样的一个左外连接,A在左,就是把
A表中的所有字段显示出来,
查出来的结果可能是null,不是0,可以用IFNULL(字段,0)这个方法,希望能帮到你
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)