MySQL中的ROW_NUMBER()
MySQL中有没有复制SQL Server函数的好方法ROW_NUMBER()
?
例如:
SELECT col1, col2,
ROW_NUMBER() OVER (PARTITION BY col1, col2 ORDER BY col3 DESC) AS intRow
FROM Table1
然后,例如,我可以添加一个条件以将限制限制intRow
为1,以获得col3
每(col1, col2)
对最高的一行。
回答:
我想要每对(col1,col2)对具有最高col3的行。
这是一个按组的最大值,是最常提出的SQL问题之一(因为它看起来应该很容易,但实际上并非如此)。
我经常为null-self-join充实:
SELECT t0.col3FROM table AS t0
LEFT JOIN table AS t1 ON t0.col1=t1.col1 AND t0.col2=t1.col2 AND t1.col3>t0.col3
WHERE t1.col1 IS NULL;
“获取表中没有匹配col1,col2的其他行具有更高col3的行。”
(您会注意到这一点,并且如果多行具有相同的col1,col2,col3,则大多数其他按组最大的解决方案将返回多行。如果这是一个问题,则可能需要一些后处理。)
以上是 MySQL中的ROW_NUMBER() 的全部内容, 来源链接: utcz.com/qa/435860.html