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));

最新文章

  1. Java进击C#——语法之IO操作
  2. Android(Linux)控制GPIO方法二
  3. 生产服务器环境最小化安装后 Centos 6.5优化配置[转]
  4. php中用于接受表单数据的$_request与$_post、$_get
  5. ActionBar官方教程(2)选主题让应用支或不支持ActionBar及支持ActionBar的应用如何隐藏和显示
  6. 关于meta定义 和 link
  7. 问题: 在使用thinkphp自带分页类时,在设置尾页显示的最后一页时,用setConfig(“last”,”尾页”)来设置样式,发现无效。
  8. @RequestBody和@ResponseBody
  9. USB_ESD处理
  10. GIT版本控制 — 简介与安装 (一)
  11. LFYZ-OJ ID: 1011 hanoi双塔问题
  12. [转帖]SAP一句话入门:Project System
  13. Django 学习第三天——模板变量及模板过滤器
  14. 超哥教你发布CRM
  15. 对信号量Semaphore的理解与运用
  16. 博客搬入CNBLOG
  17. 使用VisualStudio开发php的图文设置方法
  18. Tomcat权威指南-读书摘要系列6
  19. Backbone学习笔记 - Collection及Router篇
  20. ASP.NET配置文件Web.config 详细解释

热门文章

  1. 知识图谱实体对齐2:基于GNN嵌入的方法
  2. 利用FastReport传递图片参数,在报表上展示签名信息
  3. 9.MongoDB系列之创建副本集(二)
  4. LOJ2325「清华集训 2017」小Y和恐怖的奴隶主
  5. composer 报错 The "https://mirrors.aliyun.com/composer/p....json" file could not be downloaded (HTTP/1.1 404 Not Found)
  6. 虚拟化_Vmware——敬请期待!
  7. 后端框架学习-----mybatis(4)
  8. python更改文件后缀名
  9. 十三、Pod的资源控制器类型
  10. numpy常用知识点备忘(2)