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

sql拆分字符串實現(xiàn)一行變多行的實例代碼

 更新時間:2024年09月06日 15:48:26   作者:wjf83902  
本文主要介紹了sql拆分字符串實現(xiàn)一行變多行的實例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

一、需求

1 某一個字段中的數(shù)據(jù)為字符串拼接,要求按照特定分隔符分割成多行

2 例如(movies)表

拆分結(jié)果為:

一、pg數(shù)據(jù)庫中一行變多行

1 在pg數(shù)據(jù)庫中實現(xiàn)這種拆分有指定的函數(shù):UNNEST(STRING_TO_ARRAY(字段,'分隔符'))。

2 STRING_TO_ARRAY(字段,‘分隔符’);將字符串 -----> {字符串} 數(shù)組。

3 UNNEST 將數(shù)組拆分

4 代碼

	 SELECT 
		id,name,hobbies,
		UNNEST(string_to_array(hobbies, '、')) as tmp
	FROM movies

二、mysql數(shù)據(jù)庫中一行變多行

注:mysql 中沒有指定的函數(shù)來實現(xiàn)數(shù)據(jù)庫中一行變多行。

2.1  實現(xiàn)方式

(1)利用遞歸不停的循環(huán)拆分 -- (mysql版本必須在5.8+ 才可以用)

(2)利用一個臨時表。要求:臨時表中某一個字段的值必須是int類型且是聯(lián)系遞增的。

2.2 遞歸方式

1 代碼實現(xiàn)

	WITH RECURSIVE m(id,name,hobbies,str) AS (
	
		SELECT id,name,substr(hobbies,1,instr(hobbies,'、')-1),suubstr(concat(class,'、'),instr(class,'、')+1) 
		FROM movies m
		UNION ALL
		SELECT id,name,substr(str,1,instr(str,'、')-1),suubstr(str,instr(class,'、')+1) 
		FROM m
		WHERE instr(str,'、')>0
	)
	SELECT * FROM m ORDER BY id;

2.3 方式二  

 1 實現(xiàn)思路:我們利用substring_index函數(shù)按照指定分隔符截取字符串。

2 substring_index(str,delimiter,number) 返回從字符串 str 的第 number 個出現(xiàn)的分隔符 delimiter 之前的子串。

3 如果 number 是正數(shù),那么就是從左往右,返回第 number 個分隔符的左邊的全部內(nèi)容;number為負(fù),則相反。例如 substring_index(hobbies,'、',2),獲得的結(jié)果為:

idnamehobbiessub
1千與千尋動畫、劇情、奇幻動畫、劇情
2阿甘正傳劇情、愛情劇情、愛情
3唐伯虎點秋香喜劇、古裝、愛情喜劇、古裝

4 問題:hobbies 中每個字符串的長度是未知的,因此我們?nèi)绾闻袛嘁厝状??我們?yīng)該正向截取還是反向截取? 

以 id=1 為例:

(1)經(jīng)過分析可知,反向截取會更容易。

第一次:substring_index('動畫','、',-1) --- 得到:動畫

第二次:substring_index('動畫、劇情','、',-1) --- 得到:劇情

第三次:substring_index('動畫、劇情、奇幻','、',-1) --- 得到:奇幻

結(jié)束分割。

(2)若想實現(xiàn)上述步驟,需要動態(tài)的自動改變字段hobbies的值,將本次得到的數(shù)據(jù)給截取掉。問題:① 如何動態(tài)截取hobbies。② 截取到什么時候結(jié)束。

5 解決:

問題一:仍然利用string_index 函數(shù)進行截取

substring_index(hobbies, '、', 1) --- '動畫'

substring_index(hobbies, '、', 2) --- '動畫、劇情'

substring_index(hobbies, '、', 3) --- '動畫、劇情、奇幻'

第一次:substring_index(substring_index(hobbies, '、', 1), '、', -1) --- 得到:動畫

第二次:substring_index(substring_index(hobbies, '、', 2), '、' ,-1) --- 得到:劇情

第三次:substring_index(substring_index(hobbies, '、', 3), '、' ,-1) --- 得到:奇幻

這里的1、2、3 可以換成臨時表(tmp)中的自增id 即: substring_index(substring_index(hobbies, '、', id), '、' ,-1)。

問題二:截取多少次為止?

(1)我們可以看到有幾個分隔符,就截取 分隔符數(shù)+1次。比如:'動畫、劇情、奇幻' 有 2 個分隔符,根據(jù)上述描述可以看出需要分割3次。同理 '劇情、愛情' ,有 1 個分隔符,但是需要分割2次。

(2)因此需要截取多少次為止的問題,就轉(zhuǎn)化為了求字符串中有幾個分隔符的問題。

(3)解決:利用原始字符串的長度 - 除去分隔符的字符串的長度 = 所有分隔符的長度 = 分隔符個數(shù) * 分隔符所占字節(jié)【LENGTH(hobbies)-LENGTH(REPLACE(hobbies, '、', ''))】。注意:中文分隔符占兩個字節(jié),因此一般我們可以現(xiàn)將分隔符轉(zhuǎn)為英文字符,之后在進行計算,這樣直接得到分隔符個數(shù)。即:LENGTH(REPLACE(hobbies, '、', ','))-LENGTH(REPLACE(hobbies, '、', '')) = n。

(4)因此每一行拆分的結(jié)束條件:temp.id <LENGTH(hobbies)-LENGTH(REPLACE(hobbies, '、', ''))

6 代碼

SELECT 
	m.id,m.name,m.hobbies,
	SUBSTRING_INDEX(SUBSTRING_INDEX(m.hobbies,'、',b.help_topic_id+1),'、',-1) as tmp
		FROM `movies`m
	 inner join mysql.help_topic b
	 on b.help_topic_id<LENGTH(REPLACE(m.hobbies,'、',',')) -LENGTH(REPLACE(m.hobbies,'、','')) +1

這里用的臨時表是mysql 自帶的help_topic表。由于該表 id 是從 0 開始的,因此在進行判斷時要 +1。

注意:當(dāng)我們系統(tǒng)上線后,可能由于權(quán)限或者其他問題導(dǎo)致我們不能訪問 mysql 中自帶的表。因此為了保險起見,可以自己創(chuàng)建一個臨時表。 (只要保證其中一個字段是int類型,且連續(xù)自增即可)

到此這篇關(guān)于sql拆分字符串實現(xiàn)一行變多行的實例代碼的文章就介紹到這了,更多相關(guān)sql拆分字符串內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • SQL Server中的T-SQL的基本對象

    SQL Server中的T-SQL的基本對象

    SQL的基本對象主要有常量,表示符,分隔符,保留關(guān)鍵字。
    2010-05-05
  • 一個SQL語句獲得某人參與的帖子及在該帖得分總和

    一個SQL語句獲得某人參與的帖子及在該帖得分總和

    一個SQL語句獲得某人參與的帖子及在該帖得分總和...
    2007-04-04
  • SQL學(xué)習(xí)筆記八 索引,表連接,子查詢,ROW_NUMBER

    SQL學(xué)習(xí)筆記八 索引,表連接,子查詢,ROW_NUMBER

    SQL學(xué)習(xí)筆記八 索引,表連接,子查詢,ROW_NUMBER,學(xué)習(xí)sqlserver的朋友可以看下。
    2011-08-08
  • SQL Server 實現(xiàn)數(shù)字輔助表實例代碼

    SQL Server 實現(xiàn)數(shù)字輔助表實例代碼

    這篇文章主要介紹了SQL Server 實現(xiàn)數(shù)字輔助表的相關(guān)資料,并附實例代碼,需要的朋友可以參考下
    2016-10-10
  • 淺談SELECT?*會導(dǎo)致查詢效率低的原因

    淺談SELECT?*會導(dǎo)致查詢效率低的原因

    本文主要介紹了淺談SELECT?*會導(dǎo)致查詢效率低的原因,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • SQL 根據(jù)漢字獲取全拼的代碼

    SQL 根據(jù)漢字獲取全拼的代碼

    SQL 根據(jù)漢字獲取全拼(有些字還沒有添加上去,請自已加上去,涂聚文注)
    2009-12-12
  • Hive-SQL查詢連續(xù)活躍登錄用戶思路詳解

    Hive-SQL查詢連續(xù)活躍登錄用戶思路詳解

    這篇文章主要介紹了Hive-SQL查詢連續(xù)活躍登陸的用戶,活躍用戶這里是指連續(xù)2天都活躍登錄的用戶,本文給大家分享解決思路及sql語句,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-12-12
  • SQL如何實現(xiàn)橫表與縱表相互轉(zhuǎn)換

    SQL如何實現(xiàn)橫表與縱表相互轉(zhuǎn)換

    針對SQL橫向表轉(zhuǎn)縱向的問題,本文從實際應(yīng)用出發(fā),詳細(xì)講解了語法和操作步驟,并結(jié)合實例進行了演示和說明。文章還探討了該方法的優(yōu)缺點,提出了一些值得注意的事項,旨在幫助讀者更深入地理解這一重要的數(shù)據(jù)處理技巧
    2023-04-04
  • 解決MybatisPlus?SqlServer?OFFSET?分頁問題

    解決MybatisPlus?SqlServer?OFFSET?分頁問題

    這篇文章主要介紹了MybatisPlus?SqlServer?OFFSET?分頁問題,在分頁的時候有錯誤問題本文給大家記錄下來,方便大家查閱,需要的朋友可以參考下
    2022-04-04
  • sql server服務(wù)無法啟動的解決方案

    sql server服務(wù)無法啟動的解決方案

    sql server軟件是一款關(guān)系型數(shù)據(jù)庫管理系統(tǒng),具有使用方便可伸縮性好與相關(guān)軟件集成程度高等優(yōu)點,我們在數(shù)據(jù)編程操作時經(jīng)常會使用這款編程軟件,在編程時系統(tǒng)有時會提示sql server服務(wù)無法啟動,那么大家該如何正常啟動呢,下面就由小編來給大家介紹一下如何解決
    2023-11-11

最新評論