1

我的选择有点长,我加入了许多表。我需要做的:我选择最低价格

SELECT MIN(accomodation_price.price) AS price_from

一切都很好,直到我想按 price_from 订购结果。好的,我知道我不能使用 ORDER BY price_from 所以我尝试使用 ORDER BY MIN(accomodation_price.price) 但我想在 CASE 中使用它。我的选择效果很好,但它应用了第一个结果,它对 MIN(accomodation_price.price) 没有任何价值......首先我想要一些价值的结果,然后是其他的......

这是我的代码,带有 MIN.... 的行不起作用,我不知道为什么。我也尝试使用 WHERE IS NOT NULL 但相同....

ORDER BY

            CASE 

                WHEN accomodation.valid_to>=NOW() AND accomodation.valid_from<=NOW() THEN 0
                WHEN NOW()>accomodation.valid_to AND accomodation.valid_to!='0000-00-00' THEN 1 
                WHEN MIN(accomodation_price.price) > '0' THEN 2
                ELSE 3 END";
4

1 回答 1

1

您应该做的是将该字段(连同CASE)包含在结果数据集中,用另一个包装select,然后按该字段排序。就像是:

select * from
(select field1,field2,...,
(CASE 
WHEN accomodation.valid_to>=NOW() AND accomodation.valid_from<=NOW() THEN 0
WHEN NOW()>accomodation.valid_to AND accomodation.valid_to!='0000-00-00' THEN 1 
WHEN MIN(accomodation_price.price) > '0' THEN 2
ELSE 3 END) as field3 from table1,table2...,tableN) as R
order by R.field3
于 2013-07-09T14:51:10.553 回答