注冊|登錄

聯(lián)系電話:024-31891684  13390130939
沈陽軟件公司--沈陽軟件定制

沈陽軟件開發(fā)_沈陽軟件公司_沈陽軟件定制/軟件/最新技術(shù)

Latest technology最新技術(shù)

MySQL逗號分割字段的行列轉(zhuǎn)換技巧

瀏覽量:2752

前言:

由于很多業(yè)務表因為歷史原因或者性能原因,都使用了違反第一范式的設計模式。即同一個列中存儲了多個屬性值(具體結(jié)構(gòu)見下表)。

這種模式下,應用常常需要將這個列依據(jù)分隔符進行分割,并得到列轉(zhuǎn)行的結(jié)果。

表數(shù)據(jù):

 

ID 

Value

1

tiny,small,big

2

small,medium

3

tiny,big

期望得到結(jié)果:

 

ID

Value

1

tiny

1

small

1

big

2

small

2

medium

3

tiny

3

big

正文:

 

#需要處理的表

createtable tbl_name (ID int ,mSize varchar(100));

insertinto tbl_name values (1,'tiny,small,big');

insertinto tbl_name values (2,'small,medium');

insertinto tbl_name values (3,'tiny,big');

 

#用于循環(huán)的自增表

createtable incre_table (AutoIncreID int);

insertinto incre_table values (1);

insertinto incre_table values (2);

insertinto incre_table values (3);

 

 

selecta.ID,substring_index(substring_index(a.mSize,',',b.AutoIncreID),',',-1)

from

tbl_name a

join

incre_table b

onb.AutoIncreID <= (length(a.mSize) - length(replace(a.mSize,',',''))+1)

orderby a.ID;

 

原理分析:

這個join最基本原理是笛卡爾積。通過這個方式來實現(xiàn)循環(huán)。

以下是具體問題分析:

length(a.Size) - length(replace(a.mSize,',',''))+1 表示了,按照逗號分割后,改列擁有的數(shù)值數(shù)量,下面簡稱n

join過程的偽代碼:

根據(jù)ID進行循環(huán)

{

判斷:i 是否<= n

{

獲取最靠近第i 個逗號之前的數(shù)據(jù),即substring_index(substring_index(a.mSize,',',b.ID),',',-1)

i = i +1

}

ID = ID +1

}

總結(jié):

這種方法的缺點在于,我們需要一個擁有連續(xù)數(shù)列的獨立表(這里是incre_table)。并且連續(xù)數(shù)列的最大值一定要大于符合分割的值的個數(shù)。

例如有一行的mSize 有100個逗號分割的值,那么我們的incre_table 就需要有至少100個連續(xù)行。

當然,mysql內(nèi)部也有現(xiàn)成的連續(xù)數(shù)列表可用。如mysql.help_topic:help_topic_id 共有504個數(shù)值,一般能滿足于大部分需求了。

改寫后如下:

 

selecta.ID,substring_index(substring_index(a.mSize,',',b.help_topic_id+1),',',-1)

from

tbl_name a

join

mysql.help_topic b

onb.help_topic_id < (length(a.mSize) - length(replace(a.mSize,',',''))+1)

orderby a.ID;

沈陽團購網(wǎng)|營口網(wǎng)站制作|沈陽軟件公司|軟件定制|網(wǎng)站建設|加盟易勢|提交問題

主站蜘蛛池模板: 国产乱xxxxx97国语对白| 天堂√在线中文官网在线| 亚洲AV无码成人专区| 狼友av永久网站免费观看| 国产3级在线观看| 久久强奷乱码老熟女网站| 欧美最猛黑人xxxx黑人| 免费大片黄在线观看| 色之综合天天综合色天天棕色| 国产成年无码久久久久毛片| 91在线一区二区| 日本三级香港三级人妇m| 亚洲aⅴ无码专区在线观看q| 欧美老人巨大xxxx做受视频| 免费观看理论片毛片| 老司机无码精品A| 国产午夜一级鲁丝片| 日韩欧美一区二区三区免费看| 在丈夫面前被侵犯中文字幕| www.99精品| 成人乱码一区二区三区AV| 久久久久久久久久久久久久久 | 一卡2卡3卡4卡免费高清| 拨开内裤直接进入| 久久亚洲精品无码gv| 日韩高清在线观看| 亚洲一久久久久久久久| 欧美日韩色黄大片在线视频| 亚洲综合在线观看视频| 男人j桶进女人j的视频| 国产成人黄网在线免| 18禁无遮拦无码国产在线播放| 国内精品在线播放| 99热都是精品| 天天做天天爱夜夜爽毛片毛片 | 欧美老熟妇又粗又大| 人人爽人人澡人人高潮| 男生吃女生的jiojio| 再深点灬舒服灬太大了添老师| 美女bbbb精品视频| 国产激情久久久久影院小草|