好的我正在尝试构建一个查询,它会给我结果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这样的外部干预来重新排序所有内容。
答案 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)