加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

Mysql应用mysql 列转行,合并字段的方法(必看)

发布时间:2020-12-12 02:38:19 所属栏目:MySql教程 来源:网络整理
导读:《Mysql应用mysql 列转行,合并字段的方法(必看)》要点: 本文介绍了Mysql应用mysql 列转行,合并字段的方法(必看),希望对您有用。如果有疑问,可以联系我们。 MYSQL应用 数据表: MYSQL应用 MYSQL应用 列转行:利用max(case when then) MYSQL应用 max---聚合

《Mysql应用mysql 列转行,合并字段的方法(必看)》要点:
本文介绍了Mysql应用mysql 列转行,合并字段的方法(必看),希望对您有用。如果有疑问,可以联系我们。

MYSQL应用数据表:

MYSQL应用

MYSQL应用列转行:利用max(case when then)

MYSQL应用max---聚合函数 取最大值

MYSQL应用(case course when '语文' then score else 0 end) ---判断

MYSQL应用as 语文---别名作为列名

MYSQL应用
SELECT
 `name`,MAX(
  CASE 
  WHEN course='语文' THEN
   score
  END
 ) AS 语文,MAX(
  CASE 
  WHEN course='数学' THEN
   score
  END
 ) AS 数学,MAX(
  CASE 
  WHEN course='英语' THEN
   score
  END
 ) AS 英语
FROM
 student
GROUP BY `name`
;

MYSQL应用

MYSQL应用合并字段显示:利用group_cancat(course,”:”,”score”)

MYSQL应用
SELECT
 `name`,GROUP_CONCAT(course,":",score) AS 成绩
FROM
 student
GROUP BY
 `name`;

MYSQL应用

MYSQL应用group_concat(),手册上说明:该函数返回带有来自一个组的连接的非NULL值的字符串结果.
比较抽象,难以理解.

MYSQL应用通俗点理解,其实是这样的:group_concat()会计算哪些行属于同一组,将属于同一组的列显示出来.要返回哪些列,由函

MYSQL应用数参数(就是字段名)决定.分组必须有个标准,就是根据group by指定的列进行分组.

MYSQL应用group_concat函数应该是在内部执行了group by语句,这是我的猜测.

MYSQL应用1.测试语句:

MYSQL应用
SELECT
 GROUP_CONCAT(`name`)
FROM
 student
GROUP BY
 `name`;

MYSQL应用结果去查找name中去查找哪些值是一样的,如果相等,就全部列出来,以逗号分割进行列出,如下:

MYSQL应用group_concat('name')

MYSQL应用

MYSQL应用2.测试:

MYSQL应用
SELECT
 GROUP_CONCAT(`name`)
FROM
 student
;

MYSQL应用结果:

MYSQL应用group_concat('name')

MYSQL应用

MYSQL应用上面是否可以证明,group_concat只有与group by语句同时使用才能产生效果? 下面进行了实际测验

MYSQL应用3.测试常量对group_concat()的配置影响:

MYSQL应用SET @@GROUP_CONCAT_MAX_LEN=4

MYSQL应用手册中提到设置的语法是这样的:

MYSQL应用SET [SESSION | GLOBAL] group_concat_max_len = val;

MYSQL应用两种有什么区别?

MYSQL应用SET @@global.GROUP_CONCAT_MAX_LEN=4;
global可以省略,那么就变成了:SET @@GROUP_CONCAT_MAX_LEN=4;

MYSQL应用4.使用语句

MYSQL应用SELECT
GROUP_CONCAT(`name`)
FROM
student;

MYSQL应用结果得到:

MYSQL应用group_concat('name')

MYSQL应用

MYSQL应用结论:group_concat()函数需要与group by语句在一起使用,才能得到需要的效果.

MYSQL应用原因可以这样理解:group_concat()得到是属于x组的所有成员(函数里面列参数指定需要显示哪些字段).x组从哪里来?

MYSQL应用如果没有group by进行指定,那么根本不知道group_concat()根据哪个分组进行显示出成员. 所以,像上面没有group by子句的时候,就显示了刘备,关羽,张飞,刘备,张飞.

MYSQL应用实际中什么时候需要用到这个函数?

MYSQL应用假如需要查询的结果是这样:左边显示组名,右边想显示该组别下的所有成员信息.用这个函数,就可以省去很多事情了.

MYSQL应用另外,假如我这样使用:

MYSQL应用
SELECT
 `name`,score) AS 成绩
FROM
 student
;

MYSQL应用意义不大.

MYSQL应用group_concat()指定一个列是最好的情况.如果指定了多个列.

MYSQL应用
SELECT
 `name`,score) AS 成绩
FROM
 student
GROUP BY
 `name`;

MYSQL应用那么显示结果类似这样:

MYSQL应用group_concat(course,score)

MYSQL应用

MYSQL应用以上这篇mysql 列转行,合并字段的办法(必看)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持编程之家PHP.

欢迎参与《Mysql应用mysql 列转行,合并字段的方法(必看)》讨论,分享您的想法,编程之家 52php.cn为您提供专业教程。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读