加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > Windows > 正文

Microsoft SQL Count问题

发布时间:2020-12-13 22:36:26 所属栏目:Windows 来源:网络整理
导读:嘿聪明人.我遇到以下SQL语句的问题.我知道我不能在OnlineStatus列上做GROUP BY,这是有意义的,因为它是一个函数调用,而不是我表中的实际列.我如何修改这个以便我可以计算有多少用户在线? SELECT CASE dbo.fnGetWebUserOnlineStatus(W.Id) WHEN 1 THEN 'Onlin
嘿聪明人.我遇到以下SQL语句的问题.我知道我不能在OnlineStatus列上做GROUP BY,这是有意义的,因为它是一个函数调用,而不是我表中的实际列.我如何修改这个以便我可以计算有多少用户在线?

SELECT CASE dbo.fnGetWebUserOnlineStatus(W.Id) 
        WHEN 1 THEN 'Online' 
        WHEN 2 THEN 'Ingame' 
        ELSE 'Offline' 
       END AS OnlineStatus
FROM dbo.WebUsers W
WHERE W.[Status]=1
GROUP BY OnlineStatus

解决方法

最好使用子查询完成:

SELECT OnlineStatus,count(*)
FROM (
    SELECT  CASE dbo.fnGetWebUserOnlineStatus(W.Id) 
        WHEN 1 THEN 'Online' 
        WHEN 2 THEN 'Ingame' 
        ELSE 'Offline' 
         END AS OnlineStatus
    FROM dbo.WebUsers W
    WHERE W.[Status]=1
) sub
GROUP BY OnlineStatus

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读