MySQL - SELECT only 2 rows from each #39;group#39;(MySQL-从每个组中仅选择2行)
本文介绍了MySQL-从每个组中仅选择2行的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我正在尝试创建将用作显示信息的过滤的query。
具体地说,我希望此查询最多显示2行具有相同position值的行。
到目前为止,我已经编写了此代码,但它只显示了每个类别中的一个,我不确定我做错了什么,您能帮助我吗?
SELECT name, surname, position, value, points FROM
(SELECT name, surname, position, value, points,
@num := IF(@type = position, @num + 1, 1) AS row_number,
@type := position AS dummy
FROM players
WHERE (name LIKE '%$searchphrase%' OR surname LIKE '%$searchphrase%')
AND value >= '$minvalue'
AND value <= '$maxvalue'
GROUP BY position) AS x WHERE x.row_number <= 2
ORDER BY
CASE WHEN $filter=0 THEN points END DESC,
CASE WHEN $filter=1 THEN points END ASC,
CASE WHEN $filter=2 THEN value END DESC,
CASE WHEN $filter=3 THEN value END ASC,
CASE WHEN $filter=4 THEN surname END DESC,
CASE WHEN $filter=5 THEN surname END ASC
推荐答案
您的想法是对的。但是,MySQL不保证表达式的求值顺序。另外,子查询中有group by position。
所以我认为您可能需要:
SELECT . . .
FROM (SELECT name, surname, position, value, points,
(@num := if(@type = position, @num + 1,
if(@type := position, 1, 1)
)
) AS row_number
FROM players p CROSS JOIN
(SELECT @num := 0, @type := '') params
WHERE (name LIKE '%$searchphrase%' OR surname LIKE '%$searchphrase%') AND
value >= '$minvalue' AND value <= '$maxvalue'
ORDER BY position
) x
WHERE x.row_number <= 2
这篇关于MySQL-从每个组中仅选择2行的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
织梦狗教程
本文标题为:MySQL-从每个组中仅选择2行
基础教程推荐
猜你喜欢
- 在 MySQL 中:如何将表名作为存储过程和/或函数参数传递? 2021-01-01
- 如何根据该 XML 中的值更新 SQL 中的 XML 2021-01-01
- 什么是 orradiag_<user>文件夹? 2022-01-01
- mysql选择动态行值作为列名,另一列作为值 2021-01-01
- 在多列上分布任意行 2021-01-01
- 表 './mysql/proc' 被标记为崩溃,应该修复 2022-01-01
- MySQL 中的类型:BigInt(20) 与 Int(20) 2021-01-01
- 如何在 SQL 中将 Float 转换为 Varchar 2021-01-01
- 二进制文件到 SQL 数据库 Apache Camel 2021-01-01
- oracle区分大小写的原因? 2021-01-01
