Mysql如何将字符串按照指定字符分割
前言
在某些场景下(比如:用户上传文件或者图片等),一般的做法是将文件信息(文件名,文件路径,文件大小等)保存到文件表(user_file)中,然后再将用户所有上传的文件的id用一个指定字符拼接然后存在表(user)中某个字段里(假设是:file_ids)。
在展示用户上传的文件时就直接查询文件表中就好了:
-- 一般的语句是这样的,假设用户唯一键是id select * from file where id in(select file_ids from user where id = 1);
sql语句没有问题,文件也能查询出来,但是,上传的文件大于1个后,再用这个sql语句查询就只返回1条记录了,可能就会疑惑了,为什么只返回一条记录???;
肯定有人做过这样的验证
-- 先运行下面这个sql,正确返回1,2,3 假设上传的文件id是1,2,3; select file_ids from user where id = 1 -- 然后返回的文件id写死在sql语句中,运行成功返回3条记录 select file_ids from user where id in ('1' , '2' , '3'); -- 最后再整体试了下,结果返回一条...... select * from file where id in(select file_ids from user where id = 1) -- 然后可能会想到:我把in里面的拼接成'1','2','3',这样总可以了吧? select * from file where id in (select concat('\'', replace(file_ids,',','\',\'') ,'\'') from user where id = 1); -- concat('\'', replace(file_ids,',','\',\'') ,'\'') 确实能拼接成上面说的形式,但是结果还是只有一条
是因为这个查询只返回一个字段,所以只会返回一条记录(即使有多个逗号拼接,或者是手动拼接的,Mysql只认为是一个值,具体底层不清楚…),正确做法如下:
一:分两次查询(不是本文重点,但可以实现)
select file_ids from user where id = 1 select file_ids from user where id in ('1' , '2' , '3'); 或者 select file_ids from user where find_in_set(id , '1,2,3');
二:将file_ids字段分割成多列,类似Mysql的行转列
与Mysql行转列区别:行转列要知道列的内容,而这个不用,只需知道拼接的字符就行了
-- 下面语句将会把1,2,3,4一个字段转换成四行,依次是1,2,3,4 SELECT a.id, a.file_ids, substring_index( substring_index( a.file_ids, ',', b.help_topic_id + 1 ), ',' ,- 1 ) file_id FROM user a JOIN mysql.help_topic b ON b.help_topic_id < ( length(a.file_ids) - length(REPLACE(a.file_ids, ',', '')) + 1 ) where id = 1 ; -- 然后将上面语句写在in()里面就行了,写在in()里面的话记住只能查询一个字段哦!
上面语句可以直接复制过去,只需将a表及a表字段换成自己的表明及字段就行了,至于mysql.help_topic,是Mysql自带的,不用管的。
附:mysql如何将字符串按分隔符拆分
1.字符串拆分: SUBSTRING_INDEX(pressure 136/70 血压),例如:
SUBSTRING_INDEX(pressure ,',',1) #截取第一个逗号(,)号以前的字符串 SUBSTRING_INDEX(pressure ,',',-1) #截取倒数第一个逗号(,)号以后的字符串
2.替换函数:replace( str, from_str, to_str)。例如:
UPDATE bgs_building_copy1 SET `name`=replace(`name`,'=',""); #替换等号为空字符串
以上是Mysql如何将字符串按照指定字符分割的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

利用地理空间技术高效处理700万条记录并创建交互式地图本文探讨如何使用Laravel和MySQL高效处理超过700万条记录,并将其转换为可交互的地图可视化。初始挑战项目需求:利用MySQL数据库中700万条记录,提取有价值的见解。许多人首先考虑编程语言,却忽略了数据库本身:它能否满足需求?是否需要数据迁移或结构调整?MySQL能否承受如此大的数据负载?初步分析:需要确定关键过滤器和属性。经过分析,发现仅少数属性与解决方案相关。我们验证了过滤器的可行性,并设置了一些限制来优化搜索。地图搜索基于城

MySQL安装失败通常因缺少依赖项导致。解决方法:1.使用系统包管理器(如Linux的apt、yum或dnf,Windows的VisualC Redistributable)安装缺失的依赖库,例如sudoaptinstalllibmysqlclient-dev;2.仔细检查错误信息,逐一解决复杂的依赖关系;3.确保包管理器源配置正确,能访问网络;4.对于Windows,下载安装必要的运行库。养成阅读官方文档和善用搜索引擎的习惯,能有效解决问题。

MySQL拒启动?别慌,咱来排查!很多朋友安装完MySQL后,发现服务死活启动不了,心里那个急啊!别急,这篇文章带你从容应对,揪出幕后黑手!读完后,你不仅能解决这个问题,还能提升对MySQL服务的理解,以及排查问题的思路,成为一名更强大的数据库管理员!MySQL服务启动失败,原因五花八门,从简单的配置错误到复杂的系统问题都有可能。咱们先从最常见的几个方面入手。基础知识:服务启动流程简述MySQL服务启动,简单来说,就是操作系统加载MySQL相关的文件,然后启动MySQL守护进程。这其中涉及到配置

MySQL性能优化需从安装配置、索引及查询优化、监控与调优三个方面入手。1.安装后需根据服务器配置调整my.cnf文件,例如innodb_buffer_pool_size参数,并关闭query_cache_size;2.创建合适的索引,避免索引过多,并优化查询语句,例如使用EXPLAIN命令分析执行计划;3.利用MySQL自带监控工具(SHOWPROCESSLIST,SHOWSTATUS)监控数据库运行状况,定期备份和整理数据库。通过这些步骤,持续优化,才能提升MySQL数据库性能。

文章介绍了MySQL数据库的上手操作。首先,需安装MySQL客户端,如MySQLWorkbench或命令行客户端。1.使用mysql-uroot-p命令连接服务器,并使用root账户密码登录;2.使用CREATEDATABASE创建数据库,USE选择数据库;3.使用CREATETABLE创建表,定义字段及数据类型;4.使用INSERTINTO插入数据,SELECT查询数据,UPDATE更新数据,DELETE删除数据。熟练掌握这些步骤,并学习处理常见问题和优化数据库性能,才能高效使用MySQL。

MySQL安装报错的解决方法是:1.仔细检查系统环境,确保满足MySQL的依赖库要求,不同操作系统和版本需求不同;2.认真阅读报错信息,根据提示(例如缺少库文件或权限不足)采取对应措施,例如安装依赖或使用sudo命令;3.必要时,可尝试源码安装并仔细检查编译日志,但这需要一定的Linux知识和经验。最终解决问题的关键在于仔细检查系统环境和报错信息,并参考官方文档。

DevOps工程师常面临RDS数据库优化与更新的挑战,尤其在高负载情况下,传统方法易导致停机风险。本文介绍AWS蓝/绿部署策略,实现RDS数据库零停机时间更新。告别数据库更新停机噩梦!本文将详细讲解蓝/绿部署策略,并提供AWS环境下的操作步骤,助您在不影响服务可用性的前提下,更新RDS数据库实例。准备工作首先,协调开发团队,选择工作负载流量最低的时段进行更新。良好的DevOps实践建议提前通知团队。本例演示如何利用蓝/绿部署,在零停机时间内缩减数据库实例存储空间。您可以通过AWSRDS控制台

MySQL安装失败常见原因及解决方法:1.用户名或密码错误,或MySQL服务未启动,需检查用户名密码并启动服务;2.端口冲突,需更改MySQL监听端口或关闭占用3306端口的程序;3.依赖库缺失,需使用系统包管理器安装必要依赖库;4.权限不足,需使用sudo或管理员权限运行安装程序;5.配置文件错误,需检查my.cnf配置文件,确保配置正确。稳扎稳打,仔细排查,才能顺利安装MySQL。
