按照名称先排序,然后按照数字排序的SQL查询中,从一个分隔字符串中提取数据。
创始人
2024-08-24 22:30:07
0

假设有一个表名为data,其中包含一个名为value的字段,字段中存储了以逗号分隔的字符串。我们需要从该字段中提取数据,并按名称先排序,然后按数字排序。

以下是一个示例的解决方法:

SELECT 
  SUBSTRING_INDEX(SUBSTRING_INDEX(value, ',', numbers.n), ',', -1) AS extracted_value
FROM
  (SELECT 
    1 + units.i + tens.i * 10 AS n
  FROM
    (SELECT 0 AS i UNION ALL SELECT 1 UNION ALL SELECT 2 UNION ALL SELECT 3 UNION ALL SELECT 4 UNION ALL SELECT 5 UNION ALL SELECT 6 UNION ALL SELECT 7 UNION ALL SELECT 8 UNION ALL SELECT 9) units,
    (SELECT 0 AS i UNION ALL SELECT 1 UNION ALL SELECT 2 UNION ALL SELECT 3 UNION ALL SELECT 4 UNION ALL SELECT 5 UNION ALL SELECT 6 UNION ALL SELECT 7 UNION ALL SELECT 8 UNION ALL SELECT 9) tens
  ORDER BY
    n
  ) numbers
INNER JOIN data ON CHAR_LENGTH(value) - CHAR_LENGTH(REPLACE(value, ',', '')) >= numbers.n - 1
ORDER BY
  extracted_value;

这个查询使用了一个子查询numbers,将数字1到100生成为一个临时表。然后使用SUBSTRING_INDEX函数从分隔字符串中提取数据。CHAR_LENGTH函数用于计算字符串中逗号的数量,以确定需要提取的数据的位置。最后,使用ORDER BY对提取的值进行排序,按名称先排序,然后按数字排序。

请注意,示例中的查询假设分隔字符串中的数字是单个数字(0到9)。如果分隔字符串中的数字不是单个数字,而是更长的数字,那么上述查询需要稍作修改。

相关内容

热门资讯

透视透视挂!hhpoker软件... 透视透视挂!hhpoker软件安装包-总结开挂透视辅助插件(竟然有挂)1、hhpoker软件安装包a...
一分钟教会你“对战互娱有辅助”... 您好:对战互娱有辅助这款游戏可以开挂的,确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用户的牌特...
透视玄学!hhpoker必备开... 透视玄学!hhpoker必备开挂-总结开挂透视辅助技巧(有挂秘籍)1、完成hhpoker必备开挂的残...
科技分享“天道辅助器使用教程”... 科技分享“天道辅助器使用教程”原生有开挂辅助神器(有挂透视);一、天道辅助器使用教程有挂的是的,亲,...
终于清楚“微信边锋辅助”固有有... 终于清楚“微信边锋辅助”固有有开挂辅助插件(有挂教学)是一款可以让一直输的玩家,快速成为一个“必胜”...
透视能赢!uupoker透视-... 透视能赢!uupoker透视-解密开挂透视辅助攻略(有挂神器)所有人都在同一条线上,像星星一样排成一...
实操分享“微乐广西麻辣辅助器”... 实操分享“微乐广西麻辣辅助器”本来有开挂辅助器(有挂透明挂);微乐广西麻辣辅助器是一项微乐广西麻辣辅...
透视总结!菠萝辅助器免费版的特... 透视总结!菠萝辅助器免费版的特点-教你开挂透视辅助方法(有挂头条)1、玩家可以在菠萝辅助器免费版的特...
热点推荐“微乐小程序游戏破解器... 热点推荐“微乐小程序游戏破解器下载”真是有开挂辅助下载(有人有挂);微乐小程序游戏破解器下载AI智能...
透视新版!德州hhpoker是... 透视新版!德州hhpoker是真的-详细开挂透视辅助教程(有挂秘籍)1、这是跨平台的德州hhpoke...