您好,登錄后才能下訂單哦!
本篇文章為大家展示了SQL中怎么提取字符串中的字母,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。
具體解法
我們創建一個函數,通過調用這個函數來找出所有的字母。
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數據庫開發')
結果:
因為SQL就在第一位,所以返回結果為1
STUFF函數
STUFF ( expression1 , start , length ,expression2 )
字符串expression1 從start位置開始,刪除長度為length的字符后,在start后面填充expression2。
例如
SELECT STUFF('SQL,開發',4,1,'數據庫')
結果:
上面的示例是將","刪除后,替換成了"數據庫"
測試函數
理解完上面的函數,我們來測試一下我們自定義的函數GET_LETTER ()
SELECT dbo.GET_LETTER('SQL數1據2庫3開4發road')
結果:
這與我們預期的結果一致,證明這個自定義函數是可行的。
上述內容就是SQL中怎么提取字符串中的字母,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。