欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mysql 列轉(zhuǎn)行的技巧(分享)

 更新時間:2017年03月25日 11:28:31   投稿:jingxian  
下面小編就為大家?guī)硪黄猰ysql 列轉(zhuǎn)行的技巧(分享)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

前言:

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

這種模式下,應(yīng)用常常需要將這個列依據(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

正文:

#需要處理的表
create table tbl_name (ID int ,mSize varchar(100));
insert into tbl_name values (1,'tiny,small,big');
insert into tbl_name values (2,'small,medium');
insert into tbl_name values (3,'tiny,big');

#用于循環(huán)的自增表
create table incre_table (AutoIncreID int);
insert into incre_table values (1);
insert into incre_table values (2);
insert into incre_table values (3);
select a.ID,substring_index(substring_index(a.mSize,',',b.AutoIncreID),',',-1) 
from 
tbl_name a
join
incre_table b
on b.AutoIncreID <= (length(a.mSize) - length(replace(a.mSize,',',''))+1)
order by 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ù)值,一般能滿足于大部分需求了。

改寫后如下:

select a.ID,substring_index(substring_index(a.mSize,',',b.help_topic_id+1),',',-1) 
from 
tbl_name a
join
mysql.help_topic b
on b.help_topic_id < (length(a.mSize) - length(replace(a.mSize,',',''))+1)
order by a.ID;

以上這篇mysql 列轉(zhuǎn)行的技巧(分享)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • MySQL分頁分析原理及提高效率

    MySQL分頁分析原理及提高效率

    這篇文章主要介紹了MySQL分頁分析原理及提高效率的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • linux mysql5.6版本的安裝配置過程

    linux mysql5.6版本的安裝配置過程

    mysql官網(wǎng)開始發(fā)布相關(guān)的5.6系列的各個版本,對于mysql5.6系列的版本對一起的版本進行了全局性的細節(jié)性加強
    2013-06-06
  • MySQL參數(shù)優(yōu)化信息參考(my.cnf參數(shù)優(yōu)化)

    MySQL參數(shù)優(yōu)化信息參考(my.cnf參數(shù)優(yōu)化)

    下面針對一些參數(shù)進行說明,當然還有其它的設(shè)置可以起作用,取決于你的負載或硬件:在慢內(nèi)存和快磁盤、高并發(fā)和寫密集型負載情況下,你將需要特殊的調(diào)整
    2024-07-07
  • mysql事務(wù)處理用法與實例代碼詳解

    mysql事務(wù)處理用法與實例代碼詳解

    這篇文章主要介紹了mysql事務(wù)處理用法與實例代碼詳解,詳細的介紹了事物的特性和用法并實現(xiàn)php和mysql事務(wù)處理例子,非常具有實用價值,需要的朋友可以參考下
    2018-12-12
  • clickhouse中Nullable與非空字段的建表與類型互轉(zhuǎn)方式

    clickhouse中Nullable與非空字段的建表與類型互轉(zhuǎn)方式

    這篇文章主要介紹了clickhouse中Nullable與非空字段的建表與類型互轉(zhuǎn)方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • MySQL和Redis實現(xiàn)二級緩存的方法詳解

    MySQL和Redis實現(xiàn)二級緩存的方法詳解

    這篇文章主要給大家介紹了關(guān)于MySQL和Redis實現(xiàn)二級緩存的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-02-02
  • MySQL亂碼問題終極指南

    MySQL亂碼問題終極指南

    為了讓大家盡量在工作中少受或者不受亂碼的困擾,這篇文章主要為大家分享了MySQL亂碼問題終極指南,感興趣的小伙伴們可以參考一下
    2016-04-04
  • DBeaver連接mysql數(shù)據(jù)庫錯誤圖文解決方案

    DBeaver連接mysql數(shù)據(jù)庫錯誤圖文解決方案

    這篇文章主要給大家介紹了關(guān)于DBeaver連接mysql數(shù)據(jù)庫錯誤解決方案的相關(guān)資料,DBeaver是免費、開源、通用數(shù)據(jù)庫工具,是許多開發(fā)開發(fā)人員和數(shù)據(jù)庫管理員的所選,需要的朋友可以參考下
    2023-11-11
  • MySQL索引失效的幾種情況小結(jié)

    MySQL索引失效的幾種情況小結(jié)

    本文主要介紹了MySQL索引失效的幾種情況小結(jié),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-03-03
  • mysql釋放表空間的方法示例

    mysql釋放表空間的方法示例

    本文主要介紹了mysql釋放表空間的方法示例,可以使用OPTIMIZE TABLE命令,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2024-08-08

最新評論