当 MySQL 返回的查询结果为空(即零行)的时候 结果表示0

当 MySQL 返回的查询结果为空(即零行)的时候 结果表示0,第1张

SELECT

a.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)这个方法,希望能帮到你

IF(expr1,expr2,expr3)

如果 expr1 是TRUE (expr1 <>0 and expr1 <>NULL),则 IF()的返回值为expr2否则返回值则为 expr3。IF() 的返回值为数字值或字符串值,具体情况视其所在语境而定。

IFNULL(expr1,expr2)

假如expr1 不为 NULL,则 IFNULL() 的返回值为 expr1否则其返回值为 expr2。IFNULL()的返回值是数字或是字符串,具体情况取决于其所使用的语境。

SELECT ifnull(字段名,0) as 字段名 FROM 表名

SELECT if(字段名==NULL,0,字段名) as 字段名 FROM 表名


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/7250783.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-03
下一篇 2023-04-03

发表评论

登录后才能评论

评论列表(0条)

保存