《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`,
GROUP_CONCAT(course, ":", score) AS 成绩
FROM
student
;
MYSQL应用意义不大.
MYSQL应用group_concat()指定一个列是最好的情况.如果指定了多个列.
MYSQL应用
SELECT
`name`,
GROUP_CONCAT(course, ":", score) AS 成绩
FROM
student
GROUP BY
`name`;
MYSQL应用那么显示结果类似这样:
MYSQL应用group_concat(course,":",score)
MYSQL应用
MYSQL应用以上这篇mysql 列转行,合并字段的办法(必看)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持维易PHP.
欢迎参与《Mysql应用mysql 列转行,合并字段的方法(必看)》讨论,分享您的想法,维易PHP学院为您提供专业教程。