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

SQL?將一列拆分成多列的實現(xiàn)示例

 更新時間:2023年10月27日 09:03:14   作者:追夢的青鳥  
在SQL中,有時需要將一列數(shù)據(jù)按照特定的符號進行分割,分成多個列,本文就來介紹一下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)文章

最新評論