MySQL按指定字符合并以及拆分实例教程_Mysql

来源:脚本之家  责任编辑:小易  

mysql如何实现多行查询结果合并成一行,mysql如何实现多行查询结果合并成一行网站简介信息利用函数:group_concat(),实现一个ID对应多个名称时,原本为多行数据,把名称合并成一行。其完整语法:GROUP_CONCAT(expr)该函数返回带有来自一个组的连接的非NULL值的字符串结果。其完整的语法如下所示:GROUP_CONCAT([DISTINCT]expr[,expr.][ORDER BY {unsigned_integer|col_name|expr}[ASC|DESC][,col_name.]][SEPARATOR str_val])mysql>SELECT student_name,GROUP_CONCAT(test_score)FROM studentGROUP BY student_name;Or:mysql>SELECT student_name,GROUP_CONCAT(DISTINCT test_scoreORDER BY test_score DESC SEPARATOR ' ')FROM studentGROUP BY student_name;在MySQL中,你可以获取表达式组合的连接值。你可以使用DISTINCT删去重复值。假若你希望多结果值进行排序,则应该使用 ORDER BY子句。若要按相反顺序排列,将 DESC(递减)关键词添加到你要用ORDER BY 子句进行排序的列名称中。默认顺序为升序;可使用ASC将其明确指定。SEPARATOR 后面跟随应该被插入结果的值中间的字符串值。默认为逗号(‘,')。通过指定SEPARATOR '',你可以删除所有分隔符。使用group_concat_max_len系统变量,你可以设置允许的最大长度。程序中进行这项操作的语法如下,其中 val 是一个无符号整数:SET[SESSION|GLOBAL]group_concat_max_len=val;www.zgxue.com防采集请勿采集本网。

前言

按照指定字符进行合并或拆分是经常碰到的场景,MySQL在合并的写法上比较简单,但是按指定字符拆分相对比较麻烦一点(也就是要多写一些字符)。本文将举例演示如何进行按照指定字符合并及拆分。

select*from tb where concat(name,age)='张三20'

1、 合并

首先把要改的表名字都找出来(比如表名分别是characters1,characters2,characters3,characters4),如果想要连续的话,就把每张表你想要开始的guid找到,按昨天我写的语句就行了(select count(*)

MySQL数据库中按照指定字符合并可以直接用group_concat来实现。

数字3366中号3366 号码3366大小3366 单号3366多少3366 双号93366这是3366 什么意思

创建测试表

替换语句 update 表名 set id=replace(id,‘查找字符串’,'替换字符串')

mysql> create table tb_group(id int auto_increment primary key ,col1 varchar(20));Query OK, 0 rows affected (0.01 sec)

create table names(id int,name varchar(10));insert into names values(1,'张三') insert into names values(2,'李四') insert into names values(3,'王五') insert into names values(4,'

插入测试数据

mysql> insert into tb_group(col1) values('a'),('c'),('dddd'),('ewdw'),('vxgdh');;Query OK, 5 rows affected (0.01 sec)Records: 5 Duplicates: 0 Warnings: 0

合并col1字段的内容

默认是按照逗号进行合并的,例如:

mysql> select group_concat(col1) from tb_group; +---------------------+| group_concat(col1) |+---------------------+| a,c,dddd,ewdw,vxgdh |+---------------------+1 row in set (0.01 sec)

指定分隔符合并,例如指定使用 ||  符号进行合并

mysql> select group_concat(col1,'||') from tb_group; +-------------------------------+| group_concat(col1,'||') |+-------------------------------+| a||,c||,dddd||,ewdw||,vxgdh|| |+-------------------------------+1 row in set (0.00 sec)

注意

默认情况下,合并后的长度不能超过1024,否则结果会被截断

例如,我再写个脚本插入一些数据

# 使用shell脚本来实现vim test_insert.sh# 添加如下内容 #!/bin/bash# gjcfor i in {1..1025}do mysql -uroot -p'123456' --socket=/data/mysql3306/tmp/mysql.sock -e "insert into testdb.tb_group1(col1)values('a') "done# 运行脚本插入数据 sh test_insert.sh

mysql> select count(*)from tb_group;+----------+| count(*) |+----------+| 1030 |+----------+1 row in set (0.00 sec)

再进行合并

mysql> select group_concat(col1)cols, length(group_concat(col1)) col_len from tb_group\G*************************** 1. row *************************** cols: a,c,dddd,ewdw,vxgdh,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,col_len: 10241 row in set, 2 warnings (0.01 sec)

可以看出,结果中总长度字节只有1024

对于这种情况,实际使用时肯定是不满足的,如何解决呢?其实此长度与MySQL数据库的group_concat_max_len参数有直接关系(默认为1024)

mysql> show global variables like 'group_concat_max_len';+----------------------+-------+| Variable_name | Value |+----------------------+-------+| group_concat_max_len | 1024 |+----------------------+-------+1 row in set (0.08 sec)

那我们调整一下参数看看

/* 修改全局参数,这样所有的新连接都会生效 */mysql> set global group_concat_max_len=102400;Query OK, 0 rows affected (0.01 sec)/* 修改本会话参数,这样当前连接不用退出也可以生效 */mysql> set session group_concat_max_len=102400;Query OK, 0 rows affected (0.00 sec)mysql> show global variables like 'group_concat_max_len';+----------------------+--------+| Variable_name | Value |+----------------------+--------+| group_concat_max_len | 102400 |+----------------------+--------+1 row in set (0.00 sec)mysql> show variables like 'group_concat_max_len';+----------------------+--------+| Variable_name | Value |+----------------------+--------+| group_concat_max_len | 102400 |+----------------------+--------+1 row in set (0.01 sec)

再合并一下看看

mysql> select group_concat(col1)cols, length(group_concat(col1)) col_len from tb_group\G*************************** 1. row *************************** cols: a,c,dddd,ewdw,vxgdh,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,a,acol_len: 20691 row in set (0.01 sec)

这样结果就对了。因此生产环境中 该参数建议调整为合适的大小。

(Tips:Oracle数据库中可以使用listagg或wm_concat等多种方式实现,也比较简单,可以自行测试)

2、 拆分

按指定字符拆分字符串,也是比较常见的场景。但是MySQL数据库中字符串的拆分没有其他数据库那么方便(其他数据库直接有拆分函数),且需要借助mysql库中的mysql.help_topic表来辅助实现。例子如下:

创建测试表及数据

mysql> create table tb_split(id int primary key auto_increment,col1 varchar(20));Query OK, 0 rows affected (0.01 sec)mysql> insert into tb_split(col1) values('a,b,c,d'),('c,a,g,h');Query OK, 2 rows affected (0.01 sec)Records: 2 Duplicates: 0 Warnings: 0

按照逗号拆分

mysql> SELECT a.id, substring_index(substring_index(a.col1, ',', b.help_topic_id + 1), ',',- 1) NAME FROM tb_split a JOIN mysql.help_topic b ON b.help_topic_id < (length(a.col1) - length(REPLACE(a.col1, ',', '')) + 1);+----+------+| id | NAME |+----+------+| 1 | a || 1 | b || 1 | c || 1 | d || 2 | c || 2 | a || 2 | g || 2 | h |+----+------+8 rows in set (0.00 sec)

这样也就实现了拆分。

按指定字符拆分

如果是其他分隔符的,修改瑞阳的分隔符字段即可。

mysql> insert into tb_split(col1) values('a|v|f');Query OK, 1 row affected (0.00 sec)mysql> select * from tb_split;+----+---------+| id | col1 |+----+---------+| 1 | a,b,c,d || 2 | c,a,g,h || 3 | a|v|f |+----+---------+3 rows in set (0.01 sec)mysql> SELECT a.id, substring_index(substring_index(a.col1, '|', b.help_topic_id + 1), '|',- 1) col_split FROM tb_split a JOIN mysql.help_topic b ON b.help_topic_id < (length(a.col1) - length(REPLACE(a.col1, '|', '')) + 1) where a.id=3;+----+-----------+| id | col_split |+----+-----------+| 3 | a || 3 | v || 3 | f |+----+-----------+3 rows in set (0.00 sec)

这样就完成按照指定字符的合并及拆分了。

3、 结语

本文介绍了MySQL常用的合并及拆分方法,对于擅长写SQL的同学也可以使用其他方式实现,以便解决权限不足(例如拆分时需要使用mysql库的help_topic表的权限)等情况下的需求。

到此这篇关于MySQL按指定字符合并以及拆分的文章就介绍到这了,更多相关MySQL指定字符合并及拆分内容请搜索真格学网以前的文章或继续浏览下面的相关文章希望大家以后多多支持真格学网!

update myTable set field1='你的家'+substr(field1,7)where field1 like '我的家%'内容来自www.zgxue.com请勿采集。


  • 本文相关:
  • mysql截取和拆分字符串函数用法示例
  • mysql逗号拼接字符串查询的两种方法
  • mysql字符串拼接并设置null值的实例方法
  • mysql中字符串与num类型拼接报错的解决方法
  • mysql拼接字符串函数group_concat详解
  • mysql中null对索引的影响深入讲解
  • mysql 5.7如何安装 mysql 5.7安装配置教程
  • 详解用select命令在mysql执行查询操作的教程
  • mysql多表链接查询核心优化
  • mysql8.0.19忘记密码的完美解决方法
  • 初学者从源码理解mysql死锁问题
  • 源码编译安装mysql8.0.20的详细教程
  • php下巧用select语句实现mysql分页查询
  • php mysql localhost,127.0.0.1和ip区别
  • mysql in 与 exists 的优化示例介绍
  • mysql中怎样把一个表的所有指定字符全部替换成另外的字符?
  • Mysql 如何实现合并多行字符串
  • 求mysql语句 在指定字符串前插入换行符
  • MYSQL替换指定字符串
  • mysql 语句如何合并where字符串
  • mysql中记录合并,按字符长度范围从上到下合并记录
  • mysql字段A复制到字段B,并替换指定字符
  • mysql 查询指定id 并判断是不是包含指定的 字符串 并替换 字符串
  • MYSQL中怎么从指定的几个字符串中随机挑选一个替换原有字符串
  • mysql中如何将得到的一个字符串拆分成不同字符串添加进表中?
  • 网站首页网页制作脚本下载服务器操作系统网站运营平面设计媒体动画电脑基础硬件教程网络安全mssqlmysqlmariadboracledb2mssql2008mssql2005sqlitepostgresqlmongodbredisaccess数据库文摘数据库其它首页mysql截取和拆分字符串函数用法示例mysql逗号拼接字符串查询的两种方法mysql字符串拼接并设置null值的实例方法mysql中字符串与num类型拼接报错的解决方法mysql拼接字符串函数group_concat详解mysql中null对索引的影响深入讲解mysql 5.7如何安装 mysql 5.7安装配置教程详解用select命令在mysql执行查询操作的教程mysql多表链接查询核心优化mysql8.0.19忘记密码的完美解决方法初学者从源码理解mysql死锁问题源码编译安装mysql8.0.20的详细教程php下巧用select语句实现mysql分页查询php mysql localhost,127.0.0.1和ip区别mysql in 与 exists 的优化示例介绍mysql安装图解 mysql图文安装教程can""""t connect to mysql servwindows下mysql5.6版本安装及配置mysql字符串截取函数substring的mysql创建用户与授权方法mysql提示:the server quit withmysql——修改root密码的4种方法mysql日期数据类型、时间类型使用mysql update语句的用法详解mysql 的case when 语句使用说明linux下mysql异地自动备份的方法sysbench-0.4.12编译安装和cpu测试例子分mysql error 1045 (28000): access denie6g数据库的导入 报各种错误的解决办法sql server 2005 安装遇到的错误提示和解mysql tmp_table_size和max_heap_table_smysql中自增auto_increment功能的相关设置mysql数据库运维之数据恢复的方法mysql 的 20+ 条最佳实践mysql取得datetime类型的数据,后面会跟个
    免责声明 - 关于我们 - 联系我们 - 广告联系 - 友情链接 - 帮助中心 - 频道导航
    Copyright © 2017 www.zgxue.com All Rights Reserved