SQL?將一列拆分成多列的實現(xiàn)示例
數(shù)據(jù)庫中有業(yè)務(wù)表t1和字典表dictionary
t1表:
dictionary表:
需求一:將col列拆分成三列
SQL 代碼如下所示:
方法一:
SELECT col,a[1] a1,a[2] a2,a[3] a3 FROM ( SELECT regexp_split_to_array( col, ',' ), col FROM t1 ) AS dt (a)
效果:
方法二:
SELECT col, SPLIT_PART( col, ',', 1 ) a1, SPLIT_PART( col, ',', 2 ) a2, SPLIT_PART( col, ',', 3 ) a3 FROM t1
效果:
假設(shè)想把 "col" 列分成 "col1" 、 "col2"、 "col3",SQL語句:
1、先添加新的列
ALTER TABLE t1 ADD COLUMN col1 VARCHAR(30); ALTER TABLE t1 ADD COLUMN col2 VARCHAR(30); ALTER TABLE t1 ADD COLUMN col3 VARCHAR(30);
2、再用 SPLIT_PART
函數(shù)填充新的列
UPDATE t1 SET col1 = SPLIT_PART( col, ',', 1 ), col2 = SPLIT_PART( col, ',', 2 ), col3 = SPLIT_PART( col, ',', 3 );
效果:
需求二:列col保存的數(shù)據(jù),是字典表dictionary中id值拼接的字符串,想關(guān)聯(lián)出對應(yīng) 的name值。
SQL 代碼如下所示:
SELECT col, (SELECT name from dictionary WHERE id=a[1]) a1, (SELECT name from dictionary WHERE id=a[2]) a2, (SELECT name from dictionary WHERE id=a[3]) a3 FROM ( SELECT regexp_split_to_array( col, ',' ), col FROM t1 ) AS dt (a)
效果:
需求三:列col轉(zhuǎn)化為字典表dictionary中name拼接的字符串
SQL 代碼如下所示:
SELECT col,CONCAT_WS(',',a1,a2,a3) as names FROM ( SELECT col, (SELECT name from dictionary WHERE id=a[1]) a1, (SELECT name from dictionary WHERE id=a[2]) a2, (SELECT name from dictionary WHERE id=a[3]) a3 FROM ( SELECT regexp_split_to_array( col, ',' ), col FROM t1 ) AS dt (a) ) as temp
效果:
總結(jié) :
我們可能會遇到按分隔符拆成多行或者多列的情況,以及復(fù)制的業(yè)務(wù)需求,只需視情況調(diào)整sql語句,或者編寫存儲過程。
對于列col的值,按分隔符拆分為多列數(shù)據(jù)時,不知道需要拆分成幾列,可以先用以下sql查詢出列數(shù)。
SELECT max(array_length(regexp_split_to_array(col,','),1))
到此這篇關(guān)于SQL 將一列拆分成多列的實現(xiàn)示例的文章就介紹到這了,更多相關(guān)SQL 一列拆分成多列內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
sqlserver數(shù)據(jù)庫出現(xiàn)置疑的解決思路
首先新建一個同名的數(shù)據(jù)庫,然后再停掉sql server服務(wù),用原數(shù)據(jù)庫的數(shù)據(jù)文件覆蓋掉這個新建的數(shù)據(jù)庫文件,重啟sql server服務(wù)。感興趣的朋友可以參考下哈,希望可以幫助到你2013-03-03sql2000數(shù)據(jù)庫清除重復(fù)數(shù)據(jù)的二種方法
這篇文章主要介紹了sql2000數(shù)據(jù)庫清除重復(fù)數(shù)據(jù)的二種方法,可以使用使用游標(biāo)實現(xiàn)和sql語句實現(xiàn),需要的朋友可以參考下2014-03-03SQL Server SA權(quán)限總結(jié)經(jīng)典技術(shù)
SQL Server SA權(quán)限總結(jié)經(jīng)典技術(shù)...2006-09-09SqlServer常用函數(shù)及時間處理小結(jié)
這篇文章主要介紹了SqlServer常用函數(shù)及時間處理小結(jié),本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-05-05配置SQL Server數(shù)據(jù)庫恢復(fù)模式(2種方法)
這篇文章主要介紹了配置SQL Server數(shù)據(jù)庫恢復(fù)模式的兩種方法,需要了解的朋友可以參考下2015-10-10