SQL?將一列拆分成多列的實現示例
更新時間:2023年10月27日 09:03:14 作者:追夢的青鳥
在SQL中,有時需要將一列數據按照特定的符號進行分割,分成多個列,本文就來介紹一下SQL?將一列拆分成多列的實現示例,具有一定的參考價值,感興趣的可以了解一下
數據庫中有業(yè)務表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
效果:
假設想把 "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
函數填充新的列
UPDATE t1 SET col1 = SPLIT_PART( col, ',', 1 ), col2 = SPLIT_PART( col, ',', 2 ), col3 = SPLIT_PART( col, ',', 3 );
效果:
需求二:列col保存的數據,是字典表dictionary中id值拼接的字符串,想關聯出對應 的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轉化為字典表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
效果:
總結 :
我們可能會遇到按分隔符拆成多行或者多列的情況,以及復制的業(yè)務需求,只需視情況調整sql語句,或者編寫存儲過程。
對于列col的值,按分隔符拆分為多列數據時,不知道需要拆分成幾列,可以先用以下sql查詢出列數。
SELECT max(array_length(regexp_split_to_array(col,','),1))
到此這篇關于SQL 將一列拆分成多列的實現示例的文章就介紹到這了,更多相關SQL 一列拆分成多列內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
您可能感興趣的文章: