MYSQL GROUP_CONCAT函数

mysql 中 group_concat() 函数 完整语法

group_concat([DISTINCT] 要连接的字段 [Order BY ASC/DESC 排序字段] [Separator ‘分隔符’])

例子一:
创建数据库,并插入数据

-- ----------------------------
-- Table structure for score
-- ----------------------------
DROP TABLE IF EXISTS `score`;
CREATE TABLE `score` (
  `id` int(11) NOT NULL,
  `score` varchar(255) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

-- ----------------------------
-- Records of score
-- ----------------------------
INSERT INTO `score` VALUES ('1', '10');
INSERT INTO `score` VALUES ('1', '20');
INSERT INTO `score` VALUES ('1', '30');
INSERT INTO `score` VALUES ('2', '20');
INSERT INTO `score` VALUES ('2', '30');
INSERT INTO `score` VALUES ('2', '40');
INSERT INTO `score` VALUES ('3', '30');
INSERT INTO `score` VALUES ('3', '40');
INSERT INTO `score` VALUES ('3', '40');

效果如下图:
捕获.PNG
执行如下sql 语句:

SELECT id,GROUP_CONCAT(score) from score GROUP BY id;

捕获.PNG

SELECT id,GROUP_CONCAT(DISTINCT score) from score GROUP BY id;

捕获.PNG

SELECT id,GROUP_CONCAT(DISTINCT score ORDER BY score DESC) from score GROUP BY id;

捕获.PNG

SELECT id,GROUP_CONCAT(DISTINCT score ORDER BY score DESC SEPARATOR ";") from score GROUP BY id;

捕获.PNG
例子二:
创建表,并插入数据

-- ----------------------------
-- Table structure for grade1
-- ----------------------------
DROP TABLE IF EXISTS `grade1`;
CREATE TABLE `grade1` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `stuName` varchar(22) DEFAULT NULL,
  `course` varchar(22) DEFAULT NULL,
  `score` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=10 DEFAULT CHARSET=utf8;

-- ----------------------------
-- Records of grade1
-- ----------------------------
INSERT INTO `grade1` VALUES ('1', '张三', '语文', '91');
INSERT INTO `grade1` VALUES ('2', '张三', '数学', '90');
INSERT INTO `grade1` VALUES ('3', '张三', '英语', '87');
INSERT INTO `grade1` VALUES ('4', '李四', '语文', '79');
INSERT INTO `grade1` VALUES ('5', '李四', '数学', '95');
INSERT INTO `grade1` VALUES ('6', '李四', '英语', '80');
INSERT INTO `grade1` VALUES ('7', '王五', '语文', '77');
INSERT INTO `grade1` VALUES ('8', '王五', '数学', '81');
INSERT INTO `grade1` VALUES ('9', '王五', '英语', '89');

捕获.PNG
问题 查询语数外 三门课的最低分,还有哪个学生考的
方法一:

SELECT course,SUBSTRING_INDEX((GROUP_CONCAT(stuName ORDER BY score ASC)),',',1) as studentName,MIN(score) from grade1 GROUP BY course;

SELECT
    course,
    SUBSTRING_INDEX(
        (
            GROUP_CONCAT(stuName ORDER BY score ASC)
        ),
        ',',
        1
    ) AS studentName,
    MIN(score)
FROM
    grade1
GROUP BY
    course;

解析:

根据课程course 分组(group by),min() 函数 求该course 下的最低分
group_concat() 函数 根据分数从高到底 拼接 stuName
substring_index() 函数 拆分出 分数最低 stuName
数据量大的情况 不推荐使用该方法

方法二:

SELECT a.course,a.stuName,a.score from grade1 a where (a.score,a.course) in (SELECT MIN(score),course from grade1 GROUP BY course);

SELECT
    a.course,
    a.stuName,
    a.score
FROM
    grade1 a
WHERE
    (a.score, a.course) IN (
        SELECT
            MIN(score),
            course
        FROM
            grade1
        GROUP BY
            course
    );

捕获.PNG

解析:

min(score) group by course 可以获取到 course 的最低分,而且知道 course,socre 也可以确定是哪个学生。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
MySQL中的`group_concat`函数是一种非常实用的函数,它可以将同一个分组下的行拼接在一起。该函数的语法如下:`GROUP_CONCAT([DISTINCT] 要连接的字段 [Order BY ASC/DESC 排序字段] [Separator ‘分隔符’])`。 使用`group_concat`函数的技巧如下: 1. 建表和插入数据:首先需要创建一个表,并插入测试数据。 2. 基本查询:可以使用`SELECT * FROM table_name`语句来查询表中的数据。 3. 使用`group_concat`函数:可以使用`SELECT id, group_concat(age) FROM table_name GROUP BY id`语句来根据id分组,将age字段的值拼接成一行,使用逗号进行分隔。 4. 自定义分隔符:如果想要使用自定义的分隔符,可以在`group_concat`函数中使用`separator`关键字,如`SELECT id, group_concat(age separator ';') FROM table_name GROUP BY id`,这样就可以将age字段的值拼接成一行,使用分号进行分隔。 所以,MySQL中的`group_concat`函数可以用来将同一分组下的行拼接在一起,并可以自定义分隔符。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [mysql GROUP_CONCAT函数详解](https://blog.csdn.net/liqinglonguo/article/details/131097681)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Aloneii

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值