如何在MySql中返回的最顶部的行上执行计算?

问题描述 投票:-1回答:1

我编写了以下查询,其中使用order by子句返回了行:

SELECT host.hostname,
       cb.orderId,
       cb.status,
       cb.chefbook_name AS Heading,
       (SELECT log_message
        FROM   chefbookrun rr
        WHERE  rr.chefbook_id = c.id
        ORDER  BY id DESC 
        LIMIT  1)      AS Detail 
FROM   host
       INNER JOIN host_infl hif
               ON host.vc_server_id = hif.vc_server_id
       INNER JOIN chefcookbook cb
               ON hif.id = cb.host_id
WHERE  host.hostname REGEXP 'abc'
ORDER  BY cb.orderId; 

有几种不同类型的输出,如下所示:

hostname    orderId status  Heading         Detail
abc.com     3       30      HeadingA        Details1
abc.com     5       40      HeadingB        Details2
... more rows

hostname    orderId status  Heading         Detail
cde.com     3       40      HeadingA        Details1
cde.com     5       30      HeadingB        Details2
... more rows

hostname    orderId status  Heading         Detail
efg.com     3       50      HeadingA        Details1
efg.com     5       30      HeadingB        Details2
... more rows

我想对返回的第一行的status进行如下计算:

1) If `status is 30` then show status as `Finished`. Also `Heading` and `Detail` should be empty.

2) If `status is 40` or `status is 50` then show status as `Error`. `Heading` and `Detail` should show as such.

所需的输出如下:

hostname    orderId status     Heading          Detail
abc.com     3       Finished

hostname    orderId status  Heading         Detail
cde.com     3       Error   HeadingA        Details1

hostname    orderId status  Heading         Detail
efg.com     3       Error   HeadingA        Details1
mysql join select sql-order-by inner-join
1个回答
0
投票
SELECT host.hostname,orderId, CASE WHEN status = 30 THEN 'Finished' ELSE 'Error' END 'status', CASE WHEN status = 30 THEN '' ELSE Heading END 'Heading', CASE WHEN status = 30 THEN '' ELSE Detail END 'Detail' FROM ( SELECT host.hostname, cb.orderId, cb.status, cb.runbook_name AS Heading, ( SELECT log_message FROM runbookrun rr WHERE rr.runbook_id = c.id ORDER BY id DESC LIMIT 1 ) AS Detail FROM host INNER JOIN host_infl hif ON host.vc_server_id = hif.vc_server_id INNER JOIN chefcookbook cb ON hif.id = cb.host_id WHERE host.hostname REGEXP 'abc' ORDER BY cb.orderId ) AS temp GROUP BY hostname;
© www.soinside.com 2019 - 2024. All rights reserved.