• 首页 首页 icon
  • 工具库 工具库 icon
    • IP查询 IP查询 icon
  • 内容库 内容库 icon
    • 快讯库 快讯库 icon
    • 精品库 精品库 icon
    • 问答库 问答库 icon
  • 更多 更多 icon
    • 服务条款 服务条款 icon

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

武飞扬头像
yzhSWJ
帮助3

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

学新通

  1.  
    SELECT DISTINCT
  2.  
    (
  3.  
    substring_index( substring_index( a.col, ',', b.help_topic_id 1 ), ',',- 1 ))
  4.  
    FROM
  5.  
    ( SELECT auth col FROM `sys_user` WHERE user_id = '137' ) AS a
  6.  
    JOIN mysql.help_topic AS b ON b.help_topic_id <(
  7.  
    char_length( a.col ) - char_length(
  8.  
    REPLACE ( a.col, ',', '' )) 1
  9.  
    )

该查询语句的目的是从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列按逗号拆分成多行,并返回其中不重复的值。

学新通

这篇好文章是转载于:学新通技术网

  • 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
  • 本站站名: 学新通技术网
  • 本文地址: /boutique/detail/tanhekcakf
系列文章
更多 icon
同类精品
更多 icon
继续加载