mysql并行查询语句
简介: 在刚刚结束的乌镇世界互联网大会上,阿里云自研POLARDB云原生数据库当选世界互联网领先科技成果。POLARDB既融合了商业数据库稳定可靠、高性能、可扩展的特征,又具有开源云数据库简单开放、自...
2024.11.15MySQL GROUP_CONCAT()函数将组中的字符串连接成为具有各种选项的单个字符串,也就是实现列的合并。
测试创建一个测试表进行测试
create table test_classes (std_name varchar(200),class_name varchar(200));insert into test_classes (std_name, class_name ) value ("小明","二班") , ("小红","二班") ,("小刚","二班"), ("小强","一班"), ("小白","三班") ,("小鱼","三班");需求:查出三个班级各有什么人,并使用一个字符串的字段显示。
这时候直接使用group_concat一个语句就可以直接完成。
select class_name , group_concat(std_name) As std_names from test_classes group by class_name ;这里需要根据班级来显示,所以需要使用group_by进行分组
+------------+----------------------+| class_name | std_names |+------------+----------------------+| 一班 | 小强 || 三班 | 小白,小鱼 || 二班 | 小明,小红,小刚 |+------------+----------------------+排序:在group_concat也是支持排序的。
select class_name , group_concat(std_name order by std_name) As std_names from test_classes group by class_name ; +------------+----------------------+| class_name | std_names |+------------+----------------------+| 一班 | 小强 || 三班 | 小白,小鱼 || 二班 | 小刚,小明,小红 |+------------+----------------------+去重:可以使用DISTINCT进行去重。
insert into test_classes (std_name, class_name ) value ("小明","二班");insert into test_classes (std_name, class_name ) value ("小明","二班");select class_name , group_concat(DISTINCT(std_name)) As std_names from test_classes group by class_name ; +------------+----------------------+| class_name | std_names |+------------+----------------------+| 一班 | 小强 || 三班 | 小白,小鱼 || 二班 | 小刚,小明,小红 |+------------+----------------------+合并多列:可以配合CONCAT_WS将多列合并成一个字符串。
select group_concat(CONCAT_WS(‘的‘,class_name,std_name) SEPARATOR ‘;‘) As std_names from test_classes ; SEPARATOR 是指定分隔符```sql+---------------------------------------------------------------------------------------------------------------------------------+| std_names |+---------------------------------------------------------------------------------------------------------------------------------+| 二班的小明;二班的小红;二班的小刚;一班的小强;三班的小白;三班的小鱼;二班的小明;二班的小明 |+---------------------------------------------------------------------------------------------------------------------------------+长度限制GROUP_CONCAT这个函数是有最大长度限制的,如果超过这个长度限制,得到的字符串就是被截取后的结果,不会报错,所以需要注意。
这个是长度是由变量group_concat_max_len控制的。
show variables like "group_concat_max_len";可以通过修改这个变量来放大限制。
SET GLOBAL group_concat_max_len=102400;SET SESSION group_concat_max_len=102400;配置文件就需要在mysqld的配额节进行配置
[mysqld]group_concat_max_len=102400简介: 在刚刚结束的乌镇世界互联网大会上,阿里云自研POLARDB云原生数据库当选世界互联网领先科技成果。POLARDB既融合了商业数据库稳定可靠、高性能、可扩展的特征,又具有开源云数据库简单开放、自...
2024.11.15开发同学让我帮忙看看一个数据怎么录合适。原始的数据如下,要录入到数据库里。先取消Excel的单元格合并.删除第一行和第二行的数据,这些都是标题.然后导出CSV文件,使用文本文件编辑器打开CSV,替换 ...
2024.11.15今天学习的主要内容是刘金玉老师MySQL数据库零基础教程第24期。学习的内容是mysql数据合并查询关键词union的使用。一、合并查询union普通查询我们使用语法结构select字段from表--...
2024.11.15概述今天主要推荐一款命令行神器 —— Mycli。Mycli 是一个 MySQL 命令行客户端工具,具有自动完成和语法突出显示功能。它是由印度人基于 python 开发的一个工具,,适合初学者或者对数...
2024.11.15概述由于mysql和oracle不太一样,不支持直接的sequence,所以需要创建一张table来模拟sequence的功能。1、创建sequence表CREATE TABLE `sequence`...
2024.11.12