MySQL多排序/多组查询

时间:2012-09-08 17:43:56

标签: php mysql

好的我正在尝试构建一个查询,它会给我结果a-z并将它们分组到主要类别中。每个结果应该给我每个类别大约30个或更多的列表。但是有了这个查询。

select teamName, CONCAT(UCASE(leagueType)) as league
from fmr_teamNames 
group by leagueType 
order by teamName asc

我只会在每个类别中获得一个列表。我理解的一点是因为我按条件使用了一组。

当我稍微重新排序查询并按条件删除组时,我得到了所有列表,但它们都在z-a中。当期望的目标是类别a-z时,则每个类别的内部结果a-z

select teamName, CONCAT(UCASE(leagueType)) as league
from fmr_teamNames
order by leagueType asc

目前这给了我a-z的类别,z-a的结果。所以我对如何更好地为我的结果形成这个查询感到困惑,而不必使用像PHP这样的外部干预来重新排序所有内容。

1 个答案:

答案 0 :(得分:1)

我认为你错误地认为mysql中concat函数的group_concat函数。 Concat会将两个字符串附加在一起,而group_concat会将行合并在一起。

select teamName, group_concat(UCASE(leagueType)) as league
from fmr_teamNames 
group by teamName 
order by teamName asc

您的查询似乎也在聚合列上使用group by而不是您尝试识别的唯一列?

示例:

mysql> select * from table1;
+---------+------+------+-------------+
| autonum | ID   | name | metavalue   |
+---------+------+------+-------------+
|       1 |    1 | Rose | Drinker     |
|       2 |    1 | Rose | Nice Person |
|       3 |    1 | Rose | Runner      |
|       4 |    2 | Gary | Player      |
|       5 |    2 | Gary | Funny       |
|       6 |    2 | Gary | NULL        |
|       7 |    2 | Gary | Smelly      |
+---------+------+------+-------------+
7 rows in set (0.00 sec)

mysql> select concat(autonum, ID) from table1 group by ID;
+---------------------+
| concat(autonum, ID) |
+---------------------+
| 11                  |
| 42                  |
+---------------------+
2 rows in set (0.00 sec)

mysql> select group_concat(autonum, ID) from table1 group by ID;
+---------------------------+
| group_concat(autonum, ID) |
+---------------------------+
| 11,21,31                  |
| 42,52,62,72               |
+---------------------------+
2 rows in set (0.01 sec)