点击上方SQL数据库开发,关注获取SQL视频教程

SQL专栏

SQL数据库基础知识汇总

SQL数据库高级知识汇总

前天写了篇《》,今天再教大家如何提取中文和数字。

其实方法都是类似的,只是我们需要调整一下正则表达式而已。

提取数字

我们还是创建一个自定义函数,具体代码如下:

CREATE FUNCTION DBO.GET_NUMBER(@Str VARCHAR(100))
RETURNS VARCHAR(100)
AS
BEGIN
WHILE PATINDEX('%[^0-9]%',@Str) > 0
BEGIN
  SET @Str=stuff(@Str,PATINDEX('%[^0-9]%',@Str),1,'')
END
RETURN @Str
END
GO

测试自定义函数

SELECT dbo.GET_NUMBER('SQL数1据2库3开4发5')

结果:

提取中文字符

从提取字母和数字中,不知大家是否看出规律来了,就是在使用PATINDX函数时,后面第一个参数会相应的改变。字母的是[a-z],数字的是[0-9],那中文的是什么呢?看下面的代码

CREATE FUNCTION DBO.GET_CHINESE(@Str NVARCHAR(100))
RETURNS VARCHAR(100)
AS
BEGIN
WHILE PATINDEX('%[^吖-座]%',@Str) > 0
SET @Str = STUFF(@Str,PATINDEX('%[^吖-座]%',@Str),1,N'')
RETURN @Str
END
GO

测试自定义函数

SELECT dbo.GET_CHINESE('SQL数1据2库3开4发5')

结果:

以上就是今天要讲的内容了,觉得不错,欢迎分享给周围的朋友,谢谢~

更多推荐 没在路边改过代码的程序员,不足以谈人生 SQL如何提前字符串中的字母? Excel重大更新,VLOOKUP退役,新的搜索函数上线        

公众号内回复1,拉你进微信交流群 

长按下方二维码,和大家一起练SQL

点击"阅读原文",了解SQL训练营

更多推荐

SQL如何提取字符串中的中文和数字?