0


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

  1. 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. )

该查询语句的目的是从

  1. sys_user

表的

  1. auth

列中将数据按逗号拆分成多行,并返回其中不重复的值。

首先,它使用子查询

  1. (SELECT auth col FROM sys_user WHERE user_id = '137') AS a

来获取

  1. sys_user

表中

  1. user_id

为'137'的记录的

  1. auth

列,并将其命名为

  1. col

然后,它通过连接

  1. mysql.help_topic

表(这是MySQL系统表,用于提供帮助主题的信息)来生成一个辅助表

  1. b

,其中

  1. help_topic_id

小于

  1. (char_length(a.col) - char_length(REPLACE(a.col, ',', '')) + 1)

。这个表用来生成适当的行数,以便将

  1. col

的值按逗号分割成多行。通过将

  1. help_topic_id

的值递增,

  1. substring_index

函数可以使用它来找到逗号分割后的每个值。

最后,通过使用

  1. substring_index(substring_index(a.col, ',', b.help_topic_id + 1), ',', -1)

函数,将

  1. col

列中的值按逗号分割出来,并仅选取分割后的最后一个值。这样就可以得到不重复的值,因为

  1. DISTINCT

关键字被应用在最终的查询结果上。

总之,这个查询语句的目的是将

  1. sys_user

表中指定

  1. user_id

的记录的

  1. auth

列按逗号拆分成多行,并返回其中不重复的值。

标签: 数学建模

本文转载自: https://blog.csdn.net/yuzheh521/article/details/131399619
版权归原作者 yzhSWJ 所有, 如有侵权,请联系我们删除。

“Mysql 把某一列字段按照逗号分割”的评论:

还没有评论