Mysql 把某一列字段按照逗号分割
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
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341