Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/67.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
MySQL查询顺序(如果为null)_Mysql - Fatal编程技术网

MySQL查询顺序(如果为null)

MySQL查询顺序(如果为null),mysql,Mysql,我正在尝试构建一个具有ORDERBY语句的MySQL查询。这就是我想做的: SELECT * FROM tbl_product ORDER BY retail_price ONLY IF wholesale_price IS NULL OTHERWISE ORDER BY wholesale_price. 我不知道从哪里开始。我发现一篇文章使用ORDER BY COALESCE,但我也发现这可能会有性能问题 任何建议都将不胜感激 SELECT * FROM tbl_product OR

我正在尝试构建一个具有ORDERBY语句的MySQL查询。这就是我想做的:

SELECT * 
FROM tbl_product 
ORDER BY retail_price ONLY IF wholesale_price IS NULL OTHERWISE ORDER BY wholesale_price.
我不知道从哪里开始。我发现一篇文章使用ORDER BY COALESCE,但我也发现这可能会有性能问题

任何建议都将不胜感激

SELECT * 
FROM tbl_product 
ORDER BY ifnull(wholesale_price, retail_price);

请注意,您不需要选择排序依据的值-它可以是任何表达式

这真的救了我一命!您也可以在()之外添加asc或desc以更改顺序。:)谢谢