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

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ù)瀏覽下面的相關文章希望大家以后多多支持腳本之家! 

相關文章

  • sqlserver數據庫出現置疑的解決思路

    sqlserver數據庫出現置疑的解決思路

    首先新建一個同名的數據庫,然后再停掉sql server服務,用原數據庫的數據文件覆蓋掉這個新建的數據庫文件,重啟sql server服務。感興趣的朋友可以參考下哈,希望可以幫助到你
    2013-03-03
  • 詳解SQL Server中的事務與鎖問題

    詳解SQL Server中的事務與鎖問題

    在數據庫方面,對于非DBA的程序員來說,事務與鎖是一大難點,針對該難點,本篇文章試圖采用圖文的方式來與大家一起探討sqlserver事務與鎖問題
    2018-02-02
  • 總結SQL執(zhí)行進展優(yōu)化方法

    總結SQL執(zhí)行進展優(yōu)化方法

    談到優(yōu)化就必然要涉及索引,就像要講鎖必然要說事務一樣,建議讀者先了解一下索引。
    2015-08-08
  • sql2000數據庫清除重復數據的二種方法

    sql2000數據庫清除重復數據的二種方法

    這篇文章主要介紹了sql2000數據庫清除重復數據的二種方法,可以使用使用游標實現和sql語句實現,需要的朋友可以參考下
    2014-03-03
  • SQL開窗函數的具體實現詳解

    SQL開窗函數的具體實現詳解

    這篇文章主要介紹了SQL開窗函數的具體實現詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-07-07
  • SQL Server SA權限總結經典技術

    SQL Server SA權限總結經典技術

    SQL Server SA權限總結經典技術...
    2006-09-09
  • SqlServer常用函數及時間處理小結

    SqlServer常用函數及時間處理小結

    這篇文章主要介紹了SqlServer常用函數及時間處理小結,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-05-05
  • 配置SQL Server數據庫恢復模式(2種方法)

    配置SQL Server數據庫恢復模式(2種方法)

    這篇文章主要介紹了配置SQL Server數據庫恢復模式的兩種方法,需要了解的朋友可以參考下
    2015-10-10
  • SQL?Server備份數據庫的完整步驟

    SQL?Server備份數據庫的完整步驟

    備份是指對SQL?Server數據庫或事務日志進行的復制,下面這篇文章主要給大家介紹了關于SQL?Server備份數據庫的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-06-06
  • sql?server?累計求和實現代碼

    sql?server?累計求和實現代碼

    這篇文章主要介紹了sql?server?累計求和的實現代碼,代碼簡單易懂,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-02-02

最新評論