Sql提取(去除)字符串中所有汉字、字母、数字

目录

核心思想在于下面几个模式的组合使用:

%[0-9]%: 所有数字

%[A-Za-z]%: 所有字母

%[吖-咗]%: 所有汉字

1. 去除汉字(字母、数字):

举出一例,其他类似:

CREATE FUNCTION f_RemoveChinese
(
    @str VARCHAR(500)
)
RETURNS VARCHAR(500)
AS
BEGIN
 --  '%[0-9]%'            所有数字
 --  '%[A-Za-z]%'         所有字母
 --  '%[A-Za-z0-9]%'      所有数字与字母
 --   ....                组合使用,依此类推
    WHILE PATINDEX('%[吖-咗]%',@str) > 0
        SET @str = STUFF(@str,PATINDEX('%[吖-咗]%',@str),1,'')

    RETURN @str
END
GO

SELECT dbo.f_RemoveChinese('爱@@情123骗子我问@@你')  -- @@123@@

2. 提取汉字(字母、数字):

提取XX可转化为去除非XX。举出一例,其他类似

CREATE FUNCTION f_getChinese
(
   @str VARCHAR(500)
)
RETURNS VARCHAR(500)
AS
BEGIN
 --  '%[^0-9]%'            所有数字
 --  '%[^A-Za-z]%'         所有字母
 --  '%[^A-Za-z0-9]%'      所有数字与字母
 --   ....                组合使用,依此类推
    WHILE PATINDEX('%[^吖-咗]%',@str) > 0
        SET @str = STUFF(@str,PATINDEX('%[^吖-咗]%',@str),1,'')

    RETURN @str
END
GO

SELECT dbo.f_getChinese('爱@@情123骗子我问@@你')  -- 爱情骗子我问你

3. 提取数字(支持小数点):

上面的代码将模式直接换成 ‘%[^0-9]%‘的话,不支持带小数点的数字,下面给出一个修正的:

-- 提取所有汉字(字母、数字)
CREATE FUNCTION f_GetNum
(
	@str VARCHAR(500)
)
RETURNS VARCHAR(500)
AS
BEGIN
	-- get num and dot
	WHILE (PATINDEX('%[^0-9.]%',@str) > 0)
		SET @str = STUFF(@str,PATINDEX('%[^1-9.]%',@str),1,'')

	-- remove left dot
	WHILE(LEFT(@str,1)='.')
		SET @str = RIGHT(@str,LEN(@str)-1)

	-- remove right dot
	WHILE(RIGHT(@str,1)='.')
		SET @str = LEFT(@str,LEN(@str)-1)

	RETURN @str
END
GO

SELECT dbo.f_GetNum('爱@@..情1.23骗子我问...@@你')  -- 1.23

其他更加复杂的需求,也是在上面基础上再做一些调整与优化,总之核心思想不变。