溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

SQL中怎么提取字符串中的字母

發(fā)布時間:2021-07-26 10:48:23 來源:億速云 閱讀:198 作者:Leah 欄目:數據庫

本篇文章為大家展示了SQL中怎么提取字符串中的字母,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

具體解法

我們創(chuàng)建一個函數,通過調用這個函數來找出所有的字母。

CREATE FUNCTION dbo.GET_LETTER (@Str VARCHAR(100)) RETURNS VARCHAR(100) AS BEGIN WHILE PATINDEX('%[^a-z]%', @Str) > 0 BEGIN SET @Str = STUFF(@Str, PATINDEX('%[^a-z]%', @Str), 1, ''); END; RETURN @Str; END; GO

代碼解讀

上面的解法主要使用了兩個函數,PATINDEX函數和STUFF函數

PATINDEX函數

PATINDEX ( '%pattern%' , expression )

返回pattern字符串在表達式expression里第一次出現的位置,起始值從1開始算。

例如

SELECT PATINDEX('%SQL%','SQL數據庫開發(fā)')

結果:

SQL中怎么提取字符串中的字母

因為SQL就在第一位,所以返回結果為1

STUFF函數

STUFF ( expression1 , start , length ,expression2 )

字符串expression1 從start位置開始,刪除長度為length的字符后,在start后面填充expression2。

例如

SELECT STUFF('SQL,開發(fā)',4,1,'數據庫')

結果:

SQL中怎么提取字符串中的字母

上面的示例是將","刪除后,替換成了"數據庫"

測試函數

理解完上面的函數,我們來測試一下我們自定義的函數GET_LETTER ()

SELECT dbo.GET_LETTER('SQL數1據2庫3開4發(fā)road')

結果:

SQL中怎么提取字符串中的字母

這與我們預期的結果一致,證明這個自定義函數是可行的。

上述內容就是SQL中怎么提取字符串中的字母,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業(yè)資訊頻道。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

sql
AI