mysql 分组 列转行_MySQL数据库的分组操作,语句拼接,列转行操作

大家好,我是anyux。本文介绍MySQL数据库的分组操作,语句拼接,列转行操作。

d9ee93f222d150be4965ebe0dfe25dce.png关于group by 的sql_mode

关于group by 的sql_mode

only_full_group_by

说明:仅是MySQL5.7中存在,5.6和8.0都没有,查看sql_mode

select @@sql_mode;

在带有group by 子句的select中,select后的条件列(非主键列),要么是group by 后面的列,要么需要在函数中

示例group by 错误

select user,host from mysql.user group by user;

报错内容

ERROR 1055 (42000): Expression 2 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'mysql.user.Host' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by

解释以上报错 select 查询的字段不在 group by 子句中,并且未使用聚合函数包含'mysql.user.Host',这和sql_mode=only_full_group_by 不兼容 临时关闭sql_mode

set session sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';

永久关闭sql_mode 在/etc/my.cnf中找到[mysqld],粘贴以下内容,保存退出,重启MySQL务

sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION'

1d0b353d5a8acdc923486dc9ba56f785.pngconcat的使用

concat的使用

可以将多个列合并成一个列,做列值拼接

select concat(user,host) as 'user@host' from mysql.user;

b6710976ecbf7d9d75193940f70769c8.pnggroup_concat的使用

group_concat的使用

可以做列转行

use school;select cno as 学号, group_concat(score) as 成绩总览 from sc group by cno;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值