sqlserver筛选所有汉字、字母、数字,sqlserver通配符表达式核⼼思想在于下⾯⼏个模式的组合使⽤:
%[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)
)
regexp likeRETURNS 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
4.sql server通配符表达式
该部分转⾃:
%:匹配零个及多个任意字符; _:与任意单字符匹配; []:匹配⼀个范围; [^]:排除⼀个范围;-:连字符
Symbol Meaning
like'5[%]'5%
like'[_]n' _n
like'[a-cdf]' a, b, c, d, or f
like'[-acdf]'-, a, c, d, or f
like'[[]'[
like ']' ]
like 'abc[_]d%' abc_d and abc_de
like 'abc[def]' abcd, abce, and abcf
like '[^1-9]' 0
like '[^1-9b-z]' 0, a
对于字符串中出现的特殊字符:'%','[','[]', '_' 可以使⽤ '[]' 把它们包含起来,这样在匹配模式(pattern)中,它们就被当作普通字符对待了。
1. ⽤like'[[]'匹配特殊字符'['
select1where'[ABCDE'like'[[]%'
2. ⽤like']'匹配特殊字符']'
select1where']ABCDE'like']%'
3. ⽤like'[[]]'匹配特殊字符'[]'
select1where'[]ABCDE'like'[[]]%%'
4. ⽤like'[_]'匹配特殊字符'_'
select1where'_ABCDE'like'[_]%'
5. ⽤like'[%]'匹配特殊字符'%'
select1where'ABC%DE'like'ABC[%]DE'
对于其他的特殊字符:'^', '-', ']' 因为它们本⾝在包含在 '[]' 中使⽤,所以需要⽤另外的⽅式来转义,于是就引⼊了 like 中的 escape ⼦句,另外值得注意的是:escape 可以转义所有的特殊字符。
select1where'^ABCDE'like'!^ABCDE'escape'!'
select1where'-ABCDE'like'!-ABCDE'escape'!'
select1where']ABCDE'like'!]ABCDE'escape'!'
select1where'%ABCDE'like'\%ABCDE'escape'\'
select1where'%ABCDE'like'!%ABCDE'escape'!'
select1where'%ABCDE'like'#%ABCDE'escape'#'
select1where'%ABCDE'like'@%ABCDE'escape'@'
select1where'[ABCDE'like'![ABCDE'escape'!'
select1where']ABCDE'like'!]ABCDE'escape'!'
看出规律了吧,就是⽤ escape 后⾯紧跟着的字符来做转义字符。 escape 后⾯的字符相当于 C 语⾔字符串中的转义字符 '\'。
最后,看⼀个更加复杂的匹配,注意“-”这个也是特殊字符也需转义。
select 1 where '[^A-Z]ABCDE' like '\[\^A\-Z\]%' escape '\'
后记:⽤过正则表达式的朋友应该都知道,在正则表达式⾥可以⽤*表⽰匹配0次或是多次, [\u4e00-\u9fa5]这个可以匹配中⽂,但在这⾥我没有发现类似的功能,所以匹配⼀些复杂的语句就⽐较头疼。如我要匹配形如:印张数量*单价、200+印张数量*单价、印张数量,但不匹配形如:印张数量5*单价、印张数量6767、55印张数量uu的数据就很难实现了。
下⾯这个就是要匹配包括“纺梦”这两个字,但这两个字只能是与“+-*/”这四个字符相连或是单独存在。如果这⾥的“纺梦”是任意中⽂字符就没办法去处理了。
create table #tbl(n int,v nvarchar(100))
insert into #tbl
select1,'1+纺梦1+2'
union select2,'1+纺梦+1'
union select3,'纺梦'
union select4,'纺梦+1'
select*from #tbl
where (v like'%[+\-*/]纺梦[+\-*/]%'ESCAPE'\')
or (v like'纺梦[+\-*/]%'ESCAPE'\')
or (v like'%[+\-*/]纺梦'ESCAPE'\')
or (v ='纺梦')
--select * from #tbl
drop table #tbl
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论