【转载】SQL SERVER 通过对汉字、字母和数字的Unicode码区间的判断来识别字符串
2021/10/25 2:09:31
本文主要是介绍【转载】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.com’,char(64),‘d’)
结果:
abcd163.com
去掉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码区间的判断来识别字符串的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-01-08Docker下的SqlServer发布订阅启用
- 2023-06-05Docker安装MS SQL Server并使用Navicat远程连接
- 2023-05-25深入浅出 SQL Server CDC 数据同步
- 2023-05-12通过空间占用和执行计划了解SQL Server的行存储索引
- 2023-04-24以SQLserver为例的Dapper详细讲解
- 2022-11-30SQL server高级函数查询
- 2022-11-26SQL SERVER数据库服务器CPU不能全部利用原因分析
- 2022-11-21SQL Server 时间算差值/常用函数
- 2022-11-20调试Archery连接SQL Server提示驱动错误
- 2022-10-22SQL Server 完整、差异备份+完整、差异还原(详细讲解,规避错误)