【转载】SQL SERVER 通过对汉字、字母和数字的Unicode码区间的判断来识别字符串

发布时间:2022-07-02 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了【转载】SQL SERVER 通过对汉字、字母和数字的Unicode码区间的判断来识别字符串脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。

A~Z :65~90 a~z :97~122 0~9 : 48~57   –汉字unicode编码范围:[0x4e00,0x9fa5](或十进制[19968,40869])   SELECT * FROM dbo.person WHERE UNICODE(zz) BETWEEN 19968 AND 40869   或   WHERE UNICODE(zz) BETWEEN 0x4e00 AND 0x9fa5   经常我们会用到判断某个字符或者字符串是否包含中文,英文,特殊符号等等。这时候可以通过判断Unicode所在区间来确定某个字符所处类型。当然可以通过直接判断Unicode码,但是鉴于习惯,以下提供的是Unicode码对应的数字区间。毕竟字符的本质也就是通过二进制进行存储编码的而已。   汉字:[0x4e00,0x9fa5](或十进制[19968,40869]) 数字:[0x30,0x39](或十进制[48, 57]) 小写字母:[0x61,0x7a](或十进制[97, 122]) 大写字母:[0x41,0x5a](或十进制[65, 90]) 其他:除上所有   1.SQL trim()函数去掉两头空格   ltrim()去除左空格rtrim()去除右空格。去除两头空格就是 select ltrim(rtrim(字段))   2.replace()函数替换字符   按照ASCII码   select char(64) 对应@ 那么 select replace(‘abc@163 wangt.cc ’,char(64),‘d’)   结果: abcd163 wangt.cc   去掉tab为 select replace(‘字段’,char(9),’’)   去掉空格为 select replace(‘字段’,char(32),’’)   去掉换行为 select replace(‘字段’,char(10),’’).   SqlServer 获取字符串中小写字母的sql语句 SQL字符串截取(SubString)   作用:返回第一个参数中从第二个参数指定的位置开始、第三个参数指定的长度的子字符串。   有时候我们会截取字符串中的一些特殊想要的东西,大小写字母、模号、汉字、数字等等,今天先介绍一个获取字符串中小写字母(也是大写字母)的方式,直接上写法:  

DECLARE @s VARCHAR(MAX)= ‘AbcdEf奥奥’ --待截取字符串 
DECLARE @temp VARCHAR(MAX)=’’ --临时变量 
SELECT @temp=@temp+SUBSTRING(ch, sv.number, 1) 
FROM (SELECT @s AS ch) t 
CROSS APPLY [master].dbo.spt_values AS sv 
WHERE sv.type = ‘P’ 
AND sv.number BETWEEN 1 AND LEN(ch) 
AND ASCII(SUBSTRING(ch, sv.number, 1)) BETWEEN ASCII(‘a’) AND ASCII(‘z’) 
SELECT @temp

这样我们就获取到了小写字母,当然我们还可以获取大写字母: 

SELECT @temp=@temp+SUBSTRING(ch, sv.number, 1) 
FROM (SELECT @s AS ch) t 
CROSS APPLY [master].dbo.spt_values AS sv 
WHERE sv.type = ‘P’ 
AND sv.number BETWEEN 1 AND LEN(ch) 
AND ASCII(SUBSTRING(ch, sv.number, 1)) BETWEEN ASCII(‘A’) AND ASCII(‘Z’) 
SELECT @temp 

 

 

* 附另类判断汉字数字的SQL代码  

-- 判断汉字1汉字,0非汉字
select PATINDEX('%[吖-做]%','123')
select PATINDEX('%[吖-做]%','abc')
select PATINDEX('%[吖-做]%','')

-- 判断数字的函数
select ISNUMERIC('1')
select ISNUMERIC('a1')
select ISNUMERIC('a')

 

在 SQL Server 中处理 Unicode 字串常数时,您必需在所有的 Unicode 字串前加上大写字母 N 做为前置词,N 前置词代表的是 SQL-92 标淮中的国家语言,且必须为大写。如果您没有在 Unicode 字串常数前面加上 N 做为前置词,则 SQL Server 会在使用字串前,先将其转换成目前资料库的非 Unicode 字码页。

declare @s varchar(50);
set @s = N'';
select UniCode(@s),nchar(UniCode(@s));

 

脚本宝典总结

以上是脚本宝典为你收集整理的【转载】SQL SERVER 通过对汉字、字母和数字的Unicode码区间的判断来识别字符串全部内容,希望文章能够帮你解决【转载】SQL SERVER 通过对汉字、字母和数字的Unicode码区间的判断来识别字符串所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: