iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >Mysql 把某一列字段按照逗号分割
  • 168
分享到

Mysql 把某一列字段按照逗号分割

数学建模 2023-09-05 18:09:29 168人浏览 独家记忆
摘要

SELECT auth FROM `sys_user` WHERE user_id ='137'   SELECT DISTINCT(substring_index( substring_index( a.col,

SELECT auth FROM `sys_user` WHERE user_id ='137'

 

SELECT DISTINCT(substring_index( substring_index( a.col, ',', b.help_topic_id + 1 ), ',',- 1 )) FROM( SELECT auth col FROM `sys_user` WHERE user_id = '137' ) AS aJOIN Mysql.help_topic AS b ON b.help_topic_id <(char_length( a.col ) - char_length(REPLACE ( a.col, ',', '' ))+ 1 )

 

该查询语句的目的是从sys_user表的auth列中将数据按逗号拆分成多行,并返回其中不重复的值。

首先,它使用子查询(SELECT auth col FROM sys_user WHERE user_id = '137') AS a来获取sys_user表中user_id为'137'的记录的auth列,并将其命名为col

然后,它通过连接mysql.help_topic表(这是Mysql系统表,用于提供帮助主题的信息)来生成一个辅助表b,其中help_topic_id小于(char_length(a.col) - char_length(REPLACE(a.col, ',', '')) + 1)。这个表用来生成适当的行数,以便将col的值按逗号分割成多行。通过将help_topic_id的值递增,substring_index函数可以使用它来找到逗号分割后的每个值。

最后,通过使用substring_index(substring_index(a.col, ',', b.help_topic_id + 1), ',', -1)函数,将col列中的值按逗号分割出来,并仅选取分割后的最后一个值。这样就可以得到不重复的值,因为DISTINCT关键字被应用在最终的查询结果上。

总之,这个查询语句的目的是将sys_user表中指定user_id的记录的auth列按逗号拆分成多行,并返回其中不重复的值。

 

来源地址:https://blog.csdn.net/yuzheh521/article/details/131399619

您可能感兴趣的文档:

--结束END--

本文标题: Mysql 把某一列字段按照逗号分割

本文链接: https://www.lsjlt.com/news/395855.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作