繁体   English   中英

当count <= 3时更改另一列的值

[英]Change value of another column when count <= 3

我必须进行查询才能显示我的gridview的数据。 我正在计算每个票证类别的票证数量,但是如果该类别的票证数量少于3,则需要将其放入“其他”类别。

Select 
count(ticket.id) As 'Tickets',
if(count(ticket.id) <= 3, "Other",ticketCategoryName) As 'Ticket   Category'
FROM ds_tickets
GROUP BY 'Ticket Category

而不是像这样:

+----------------+-------------+
| TicketCategory | TicketCount |
+----------------+-------------+
| Category1      |           2 |
| Category2      |           3 |
| Category3      |           4 |
| Category4      |           5 |
+----------------+-------------+

我希望它像:

+----------------+-------------+
| TicketCategory | TicketCount |
+----------------+-------------+
| Other          |           5 |
| Category3      |           4 |
| Category4      |           5 |
+----------------+-------------+

试试这样的事情

SELECT CASE WHEN CNT <= 3 THEN 'Other' ELSE TicketCategory END 'Ticket Category' ,
      SUM(CNT)
FROM( 
    SELECT  TicketCategory, COUNT(*) as CNT
    FROM Table
    GROUP BY  TicketCategory
)M
GROUP BY CASE WHEN CNT <= 3 THEN 'Other' ELSE TicketCategory END

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM