表结构
+-------+---------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+---------------+------+-----+---------+-------+
| SId | varchar(10) | YES | | NULL | |
| CId | varchar(10) | YES | | NULL | |
| score | decimal(18,1) | YES | | NULL | |
+-------+---------------+------+-----+---------+-------+
按照学生 SId 统计不同学生的总分数并且显示排名
我的 sql 语句
select t1.SId, t1.total_score, count(t2.total_score)+1 rank from
(select score.SId, sum(score) total_score from score group by SId) t1
left join
(select score.SId, sum(score) total_score from score group by SId) t2
on t1.SId = t2.SId and t2.total_score > t1.total_score
order by rank asc
报错提示:
In aggregated query without GROUP BY, expression #1 of SELECT list contains nonaggregated column 't1.SId'; this is incompatible with sql_mode=only_full_group_by
mysql 版本:5.7.30
网上说更改相关的配置就可以, 但是除了更改相关 mysql 配置还有什么办法更改 sql 语句来解决这个错误呢
1
richard1122 2020-06-08 16:56:21 +08:00
如果你确定这个字段可以任意取值,可以用 any_value(score.SId),或者例如 min, max 这类
|
2
richard1122 2020-06-08 16:57:25 +08:00
打错了,应该是 any_value( t1.SId ) ,其它字段类似
|
3
18870715400 OP @richard1122 表结构中就有这个字段啊,加上 any_value 就识别不了了
|
4
richard1122 2020-06-08 17:03:22 +08:00
|
5
l00t 2020-06-08 17:04:18 +08:00
把句子写对就能解决错误啊……
|
6
18870715400 OP @richard1122 你的链接地址文章的意思是 select 的字段如果运用了了 group by 则必须在 group by 中出现或者是聚合函数中的虚拟字段, 但是我的
select score.SId, sum(score) total_score from score group by SId 中的 score.SId 和 sum(score)都是在内的啊, 就是报 t1.SId 的错误 |
7
richard1122 2020-06-08 17:16:35 +08:00
@18870715400 #6 因为你 count(t2.total_score) 隐含了 group by
|
8
wzq001 2020-06-08 17:22:06 +08:00
弱弱的问一句,是不是这种类型的
https://blog.csdn.net/qq_33801738/article/details/99438496 |
9
18870715400 OP |