在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
前言 有时会遇到没有遵守第一范式设计模式的业务表。即一列中存储了多个属性值。如下表
一般有这两种常见需求(测试数据见文末) 1.得到所有的不重复的值,如
SQL如下: select distinct(substring_index(substring_index(a.col,',',b.help_topic_id+1),',',-1)) from (select group_concat(distinct `value`) as col from `row_to_col`) as a join mysql.help_topic as b on b.help_topic_id < (char_length(a.col) - char_length(replace(a.col,',',''))+1) 2.显示每个值及其对应主键,如
SQL如下: select a.pk,substring_index(substring_index(a.col,',',b.help_topic_id+1),',',-1) from (select `value` as col,pk from `row_to_col`) as a join mysql.help_topic as b on b.help_topic_id < (char_length(a.col) - char_length(replace(a.col,',',''))+1) 实现思路: 需求1: 1. 通过group_concat函数将value列的值拼接成一个逗号隔开的字符串,然后通过substring_index函数对字符串进行截取 注意: 需求2:思路基本与需求1同,只是最后的查询不一样 涉及到的函数: length:返回字符串所占的字节数,是计算字段的长度。一个汉字或是中文符号是算三个字符,一个数字或字母或英文符号算一个字符。 测试数据: DROP TABLE IF EXISTS `row_to_col`; CREATE TABLE `row_to_col` ( `pk` int(11) NOT NULL AUTO_INCREMENT, `value` varchar(255) DEFAULT NULL, PRIMARY KEY (`pk`) ) ENGINE=InnoDB AUTO_INCREMENT=8 DEFAULT CHARSET=utf8; INSERT INTO `row_to_col` VALUES ('1', 'ET,AT'); INSERT INTO `row_to_col` VALUES ('2', 'AT,BT'); INSERT INTO `row_to_col` VALUES ('3', 'AT,DT'); INSERT INTO `row_to_col` VALUES ('4', 'DT,CT,AT'); 参考: 到此这篇关于MySQL中将一列以逗号分隔的值行转列的实现的文章就介绍到这了,更多相关MYSQL 逗号分割行转列内容请搜索极客世界以前的文章或继续浏览下面的相关文章希望大家以后多多支持极客世界! |
请发表评论