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('%[^0-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

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。