繁体   English   中英

将多行值合并为一个

[英]Combining multiple rows values into single

有几行:

Id marks 
1  15   
1  16
1  17  
2  6
2  15
3  9
3  10

我想将所有id合并到一行,输出如下:

 Id  marks1 marks2 marks3 
 1   15    16      17
 2   6     15
 3   9     10

在mysql中,将字段串联为单个字段非常容易。 有它的功能。 CONCAT() 更好的是,如果您想用相同的字符串分隔它们,则可以使用CONCAT_WS() 它与分隔符串联在一起,第一个参数是分隔符,后面是要加入的字段后的任何其他参数。

http://www.w3resource.com/mysql/string-functions/mysql-concat_ws-function.php

SELECT id, CONCAT_WS(' ', marks1, marks2, marks3) as 'mark1 | mark2 | mark3' from my_table group by id;

更新

我想我误解了您的架构结构。 我认为您实际上正在寻找的是GROUP_CONCAT()

http://www.w3resource.com/mysql/aggregate-functions-and-grouping/aggregate-functions-and-grouping-group_concat.php

SELECT id, GROUP_CONCAT(marks) as 'All Marks' from my_table group by id;

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM