V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
18870715400
V2EX  ›  问与答

有关于一个 sql 语句错误的例子

  •  
  •   18870715400 · Jun 8, 2020 · 1585 views
    This topic created in 2162 days ago, the information mentioned may be changed or developed.

    表结构

    +-------+---------------+------+-----+---------+-------+
    | 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 语句来解决这个错误呢

    10 replies    2020-06-08 17:49:30 +08:00
    richard1122
        1
    richard1122  
       Jun 8, 2020
    如果你确定这个字段可以任意取值,可以用 any_value(score.SId),或者例如 min, max 这类
    richard1122
        2
    richard1122  
       Jun 8, 2020
    打错了,应该是 any_value( t1.SId ) ,其它字段类似
    18870715400
        3
    18870715400  
    OP
       Jun 8, 2020
    @richard1122 表结构中就有这个字段啊,加上 any_value 就识别不了了
    l00t
        5
    l00t  
       Jun 8, 2020
    把句子写对就能解决错误啊……
    18870715400
        6
    18870715400  
    OP
       Jun 8, 2020
    @richard1122 你的链接地址文章的意思是 select 的字段如果运用了了 group by 则必须在 group by 中出现或者是聚合函数中的虚拟字段, 但是我的
    select score.SId, sum(score) total_score from score group by SId
    中的 score.SId 和 sum(score)都是在内的啊, 就是报 t1.SId 的错误
    richard1122
        7
    richard1122  
       Jun 8, 2020
    @18870715400 #6 因为你 count(t2.total_score) 隐含了 group by
    wzq001
        8
    wzq001  
       Jun 8, 2020
    弱弱的问一句,是不是这种类型的
    https://blog.csdn.net/qq_33801738/article/details/99438496
    18870715400
        9
    18870715400  
    OP
       Jun 8, 2020
    @wzq001
    题目地址: https://www.jianshu.com/p/476b52ee4f1b
    都是类似的, 需要表自交,但是这个需要先将分数加起来再排名,多了一步加分数
    w830I8ikCnasfN4q
        10
    w830I8ikCnasfN4q  
       Jun 8, 2020
    select (@i:=@i+1) rank,s.SId,sum(s.score) total_score from score as s,(select @i:=0) as it group by s.SId
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   874 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 137ms · UTC 21:38 · PVG 05:38 · LAX 14:38 · JFK 17:38
    ♥ Do have faith in what you're doing.