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; MYSQL应用4.使用语句 MYSQL应用SELECT 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为您提供专业教程。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |