php – 使用MySQL的UNION中每个SELECT的不同ORDER BY

前端之家收集整理的这篇文章主要介绍了php – 使用MySQL的UNION中每个SELECT的不同ORDER BY前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

使用PHPMysqL,有没有办法为UNION中的每个SELECT语句使用不同的ORDER BY?

SELECT * FROM the_table WHERE color = 'blue' ORDER BY price ASC LIMIT 5
UNION ALL
SELECT * FROM the_table WHERE color = 'red' ORDER BY RAND() LIMIT 10

以上陈述不起作用.看来你只能对最终结果集进行ORDER BY.有没有办法在第一个SELECT上执行ORDER BY,然后使用UNION在第二个SELECT上执行不同的ORDER BY?

最佳答案
(SELECT * FROM the_table WHERE color = 'blue' ORDER BY price ASC LIMIT 5)
UNION ALL
(SELECT * FROM the_table WHERE color = 'red' ORDER BY RAND() LIMIT 10)

猜你在找的MySQL相关文章