繁体   English   中英

MySQL:按两列函数排序

[英]MySQL: Order by a function of two columns

我在表T中有两个整数字段A和B.

我想做类似“ SELECT * FROM T ORDER BY f(A,B) DESC ”之类的事情

其中f(A,B)是A和B的线性组合......即f(A,B) = mA + nB ,其中m和n是数字。

什么是正确的语法?

你有两个选择(至少):

SELECT (n * A + m * B) AS C, *
  FROM T
 ORDER BY C DESC; -- or ORDER BY 1 DESC

要么:

SELECT *
  FROM T
 ORDER BY (n * A + m * B) DESC;

一个或另一个 - 可能两者 - 应该在MySQL中为你工作。 第一个应该工作,即使第二个没有。

尽量保持简单,使用以下内容:

SELECT * FROM T ORDER BY (m * A + n * B) DESC

其中m和n是你的责任。

暂无
暂无

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

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