SQL数据库类似正则表达式的字符处理问题

SQL数据库类似正则表达式的字符处理问题插图亿华云

SQL Serve提供了简单的字符模糊匹配功能,比如:like, patindex,不过对于某些字符处理场景还显得并不足够,日常碰到的几个问题有:

同一个字符/字符串,出现了多少次同一个字符,第N次出现的位置多个相同字符连续,合并为一个字符是否为有效IP/身份证号/手机号等一. 同一个字符/字符串,出现了多少次

同一个字符,将其替换为空串,即可计算

declare @text varchar(1000)

declare @str varchar(10)

set @text = ABCBDBE

set @str = B

select len(@text) - len(replace(@text,@str,))

同一个字符串,仍然是替换,因为是多个字符,方法1替换后需要做一次除法;方法2替换时增加一个字符,则不需要

—方法1

declare @text varchar(1000)

declare @str varchar(10)

set @text = ABBBCBBBDBBBE

set @str = BBB

select (len(@text) - len(replace(@text,@str,)))/len(@str)

—方法2

declare @text varchar(1000)

declare @str varchar(10)

set @text = ABBBCBBBDBBBE

set @str = BBB

select len(replace(@text,@str,@str _)) - len(@text)二. 同一个字符/字符串,第N次出现的位置

SQL SERVER定位字符位置的函数为CHARINDEX:

CHARINDEX ( expressionToFind , expressionToSearch [ , start_location ]
)CHARINDEX ( expressionToFind , expressionToSearch [ , start_location ] )

可以从指定位置起开始检索,但是不能取第N次出现的位置,需要自己写SQL来补充,有以下几种思路:

1、 自定义函数, 循环中每次为charindex加一个计数,直到为N

if object_id(NthChar,FN) is not null

drop function Nthchar

GO

create function NthChar

(

@source_string as nvarchar(4000),

@sub_string as nvarchar(1024),

@nth as int

)

returns int

as

begin

declare @postion int

declare @count int

set @postion = CHARINDEX(@sub_string, @source_string)

set @count = 0

while @postion

THE END
Copyright © 2024 亿华云