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函数