当前位置: 首页 > 编程日记 > 正文

SQLserver 常用函数适用方法(转载)

SQL Server 常用函数使用方法(持续更新)

之前就想要把一些 SQL 的常用函数记录下来,不过一直没有实行。。。嘿嘿。。。

直到今天用到substring()这个函数,C# 里面这个方法起始值是 0,而 SQL 里面起始值是 1。傻傻分不清楚。。。

这篇博客作为记录 SQL 的函数的使用方法,想到哪里用到哪里就写到哪里。。。

SubString():用于截取指定字符串的方法。该方法有三个参数:

参数1:用于指定要操作的字符串。

参数2:用于指定要截取的字符串的起始位置,起始值为 1 。

参数3:用于指定要截取的长度。

select substring('abcdef',1,3)    -- 返回 abcselect substring('123456321',0,2)    -- 返回 1,即第一位,最好不要这样做

Left():用于返回指定字符串中指定长度的左侧部分。该方法有两个参数:

参数1:用于指定要操作的字符串。

参数2:用于指定要返回的子字符串的长度。

select LEFT('abc123',3)        -- 返回 abcselect LEFT('左侧部分右侧部分',4)    -- 返回 左侧部分

Right():用于返回指定字符串中指定长度的右侧部分。该方法有两个参数:

参数1:用于指定要操作的字符串。

参数2:用于指定要返回的子字符串的长度。

select RIGHT('abc123',3)        -- 返回 123select RIGHT('左侧部分右侧部分',4)    -- 返回 右侧部分

CharIndex():用于返回指定字符串中指定子字符串出现的起始位置。如果未找到就返回 0。该方法有两个参数:

参数1:用于指定要进行查找的字符串。

参数2:用于指定用作检索的字符串。

select charindex('a','123a123')        -- 返回 4select charindex('abc','123a123')    -- 返回 0select charindex('abc','123abc123')    -- 返回 4

Stuff():用于删除指定长度的字符,并在删除的位置插入新的字符/值。该方法有四个参数:

参数1:用于指定要操作的字符串。

参数2:用于指定要删除字符的起始位置。

参数3:用于指定要删除字符的长度。

参数4:用于指定在删除的位置插入的新的字符串/值。

select stuff('123abc456',4,3,'ABC')        -- 返回 123ABC456select stuff('123abc456',1,3,'')    -- 返回 abc456,用空字符串替代

 Len():用于返回指定文本的值的长度。前导空格计算在内,尾随空格不计算在内。该方法有一个参数:

参数1:用于指定要操作的文本或字符串。

select len('123')    -- 返回 3select len('字符串')    -- 返回 3

Difference():用于返回一个整数值,指示两个字符表达式的 SOUNDEX 值之间的差异。(即两个字符串的相似度)那么什么是 SOUNDEX 值呢?先记着,下面轮到它了。

返回的值从 0 到 4 不等:0 表示几乎不同或完全不同,4 表示几乎相同或完全相同。该方法有两个参数:

参数1:用于指定要进行比对的第一个字符串 SOUNDEX 值 。

参数2:用于指定要进行比对的第二个字符串 SOUNDEX 值。

select difference('action','demo')        -- 返回 2select difference('123456','整数')        -- 返回 4

Soundex():用于返回指定字符串的 SOUNDEX 值。SOUNDEX是一种语音算法,利用英文字的读音计算近似值,值由四个字符构成,第一个字符为英文字母,后三个为数字。在拼音文字中有时会有会念但不能拼出正确字的情形,可用 Soundex 做类似模糊匹配的效果。这里的模糊匹配跟 LIKE 不同。

算法简要说明:

复制代码
-- 将英文字按以下规则替换(不使用第一个字符进行匹配,并且不使用对应值为 0 的英文字符的值)a e h i o u w y -> 0b f p v -> 1c g j k q s x z -> 2d t -> 3l -> 4m n -> 5r -> 6
复制代码

如果字符串中存在拥有相同对应数字的2个或以上的字母在一起(例如 j 和 k),则删除其他的,只保留1个。去除对应值为 0 的字符,只返回前4个字节,不够用 0 填充。

select soundex('string')    -- 返回 S215select soundex('str')    -- 返回 S210
select soundex('123')    -- 返回 0000select soundex('字符串')    -- 返回 0000

PS:除英文字符以外的字符都将返回 0000,所以上面的方法 Difference() 的第二个示例会返回4(表示完全相同)。

Lower():用于返回指定英文字符串的小写形式的字符串。如果不为英文字符串,则返回原值。该方法有一个参数:

参数1:用于指定要转换为小写形式的字符串。

select lower('ABC')        -- 返回 abcselect lower('123')    -- 返回 123

Upper():用于返回指定英文字符串的大写形式的字符串。如果不为英文字符串,则返回原值。该方法有一个参数:

参数1:用于指定要转换为大写形式的字符串。

select upper('abc')        -- 返回 ABCselect upper('123')    -- 返回 123

Ltrim():用于返回删除前导空格之后的字符串。该方法有一个参数:

参数1:用于指定要进行删除前导空格操作的字符串。

复制代码
select ltrim('        123')        -- 返回 123select ltrim('        好多空格')    -- 返回 好多空格select len('        123')    -- 返回 11select len(ltrim('        123'))  -- 返回 3
复制代码

Rtrim():用于返回截断尾随空格之后的字符串。该方法有一个参数:

参数1:用于指定要进行截断尾随空格操作的字符串。

select rtrim('123         ')        -- 返回 123select len(rtrim('123         '))  -- 返回 3

Replace():用第三个表达式替换第一个字符串表达式中出现的所有第二个给定字符串表达式。该方法有三个参数:

参数1:用于指定要操作的字符串,即被匹配的字符串。

参数2:用于指定要进行匹配的字符串。

参数3:用于指定用作替换存在的匹配项的字符串。

--把 abc 替换为 xxx 
select replace('123abc456','abc','xxx')        -- 返回 123xxx456-- 用空字符串替换匹配项
select replace('123abc456','abc','')    -- 返回 123456

 Unicode():根据 Unicode 标准返回指定字符或字符串的第一个字符的整数值。该方法有一个参数:

参数1:用于指定要操作的字符或字符串。

select unicode('a')        -- 返回 97select unicode('abc')    -- 返回 97,只返回第一个字符

NChar():根据 Unicode 标准返回指定整数值代码的 Unicode 字符。该方法有一个参数:

参数1:指定一个 Unicode 标准的整数值代码。

select nchar(97)    -- 返回 aselect nchar(65)    -- 返回 A

Char():将指定的 int 类型的值转换为 ASCII 代码。该方法有一个参数:

参数1:指定一个 int 类型的数值,值范围为 0 至 255。返回 null 表示整数表达式不是在此范围内。

复制代码
select char(99)    -- 返回 cselect char(9)    -- Tab符select char(10)    -- 换行符select char(13)    -- 回车符
复制代码

ASCII():返回指定字符或字符串的第一个字符的 ASCII 代码值。该方法有一个参数:

参数1:用于指定要操作的字符或字符串。

select ascii('A')    -- 返回 65select ascii('a')    -- 返回 97

PS:ASCII() 用于操作单字节,双字节请使用 Unicode()。全角字符为双字节、中文字符为双字节。

示例:

复制代码
select unicode('字符串')    -- 返回 23383select nchar('23383')    -- 返回 字select char('23383')    -- 返回 NULLselect ascii('字符串')    -- 返回 215select nchar('215')    -- 返回 ×select char('215')    -- 返回 NULLselect ascii('Kan')    -- 返回 75select nchar('75')    -- 返回 Kselect char('75')    -- 返回 K
复制代码

Str():返回一个指定数值的等效字符串。该方法有三个参数:

参数1:指定要操作的数值。

参数2:指定要返回字符串的长度。默认值为10,即不指定默认长度为10,不足用空字符填充。

参数3:要返回的小数位数。默认值为0,即不指定就不保留小数,不足指定位数,用0补充。

复制代码
select str(123.10)    -- 返回        123select len(str(123.10))    -- 返回 10select str(123.10,5)    -- 返回   123select len(str(123.10,5))    -- 返回 5select str(123.10,20,5)        -- 返回            123.10000select len(str(123.10,20,5))    -- 返回 20
复制代码

Space():用于返回指定数值长度的空格字符串。该方法有一个参数:

参数1:指定返回空格字符串的长度。

select '1'+space(3)+'2'        -- 返回 1   2select len('1'+space(3)+'2')    -- 返回 5

Reverse():用于对指定字符串进行反转,按照单个字符进行反转。该方法有一个参数:

参数1:指定需要执行反转操作的字符串。

select reverse('123')    -- 返回 321select reverse('abc')    -- 返回 cba

Replicate():用于返回一个对指定字符串重复指定次数后的字符串。该方法有两个参数:

参数1:用于指定要操作的字符串。

参数2:用于指定字符串重复的次数。如果为0,返回空字符串;如果为负数,则返回 null。

select replicate('123',3)    -- 返回 123123123select replicate('a',3)        -- 返回 aaa

Quotename():返回一个 Unicode 字符串,根据指定分隔符,返回一个有效的字符串标识符。该方法有两个参数:

参数1:用于指定要操作的字符串。

参数2:用于指定分隔符,可以是单引号(')、左括号([)、右括号(])、左右括号([])或双引号(")。如果未指定,默认使用左右括号。

复制代码
select quotename('123','[]')    -- 返回 [123]select quotename('123','''')    -- 返回 '123'select quotename('123','"')        -- 返回 "123"select quotename('12[]3','[]')    -- 返回 [12[]]3],右括号加倍表示转义字符。
复制代码

Patindex():返回指定字符串表达式中指定模式第一次出现的起始位置,未找到则返回0。该方法有两个参数:

参数1:指定要匹配的字符串及匹配模式。

参数2:指定要被匹配的字符串表达式。

复制代码
select Patindex('abc','123abc456abc789')    -- 返回 0select Patindex('abc','abc')    -- 返回 1select Patindex('abc%','123abc456abc789')    -- 返回 0select Patindex('%abc%','123abc456abc789')    -- 返回 4select Patindex('%[abc]%','123abc456abc789')    -- 匹配字符串 abc 第一次出现的位置,返回 4select Patindex('%[^abc]%','123abc456abc789')    -- 匹配不等于字符 a、b、c 的其他字符第一次出现的位置,返回 1select Patindex('%[^abc]%','b123abc456abc789')    -- 匹配不等于字符 a、b、c 的其他字符第一次出现的位置,返回 2
复制代码

Parsename():返回对象名称的指定部分。 可检索的对象部分包括对象名称、所有者名称、数据库名称和服务器名称。其实也可以用于截取字符串。该方法有两个参数:

参数1:要检索其指定部分的对象的名称。此名称可包含四部分:服务器名称、数据库名称、所有者名称以及对象名称。

参数2:要返回的对象部分。只能为1至4的数值。1 = 对象名称;2 = 架构名称;3 = 数据库名称;4 = 服务器名称

select parsename('server.dbo.dbTest.table',1) tablename,parsename('server.dbo.dbTest.table',2) dbname,parsename('server.dbo.dbTest.table',3) schemaname,parsename('server.dbo.dbTest.table',4) servername

这种截取方式类似于字符串分割,不过这里是倒着截取的,所以在一定程度上可以用于字符串的截取。不过只支持小数点(.)的分割,而且只支持四位。

select parsename('192.168.1.1',4) col1,parsename('192.168.1.1',3) col2,parsename('192.168.1.1',2) col3,parsename('192.168.1.1',1) col4

Getdate():获取当前日期时间。

select getdate()

Year():获取指定日期表达式的年。该方法有一个参数:

参数1:指定要操作的日期表达式。

select year('2016-01-01')    -- 返回 2016select year('2017-01-01 12:30:30')    -- 返回 2017select year(getdate())    -- 返回 2017

Month():获取指定日期表达式的月。该方法有一个参数:

参数1:指定要操作的日期表达式。

select month('2016-01-01')    -- 返回 1select month('2017-10-01 12:30:30')    -- 返回 10select month(getdate())    -- 返回 5

Day():获取指定日期表达式的日。该方法有一个参数:

参数1:指定要操作的日期表达式。

select day('2016-01-01')    -- 返回 1select day('2017-10-03 12:30:30')    -- 返回 3select day(getdate())    -- 返回 11

Isdate():用于判断指定的字符串表达式是否为日期。返回 1,表示指定字符串表达式是日期。返回 0,表示指定字符串表达式不是日期。该方法有一个参数:

参数1:用于指定要操作的字符串表达式。

复制代码
select isdate('10/30/2017')        -- 月/日/年        返回 1select isdate('30/10/2017')        -- 日/月/年        返回 0select isdate('2017/10/30')        -- 年/月/日        返回 1select isdate('02/29/2017')        --用于判断闰年,由于2017不是闰年,所以没有29     返回 0select isdate('2017-01-01')        -- 返回 1select isdate('2017-01-01 10:10:10')    -- 返回 1select isdate('01-01-2017')        -- 返回 1select isdate('01-01-2017 10:10:10')    -- 返回 1
复制代码

Datename():返回指定日期的指定日期的部分的字符串。该方法有两个参数:

参数1:指定返回指定日期的指定部分的字符串。可以为下图中的日期部分或者缩写。

参数2:指定要操作的日期字符串。

复制代码
select datename(year,'2017-01-01 10:10:10')    -- 返回 2017
select datename(yyyy,'2017-01-01 10:10:10')    -- 返回 2017select datename(month,'2017-01-01 10:10:10')    -- 返回 01
select datename(mm,'2017-01-01 10:10:10')    -- 返回 01select datename(quarter,'2017-05-02 10:10:10')        -- 表示一年的第几个季度        返回 2
select datename(weekday,'2017-02-02 10:10:10')        -- 表示一周的星期几        返回 星期四
select datename(week,'2017-02-02 10:10:10')        -- 表示一年的第几周        返回 5
select datename(dayofyear,'2017-02-02 10:10:10')        -- 表示一年的第几天        返回 33select datename(hh,'2017-01-01 10:30:25')    -- 返回 10
复制代码

Datepart():返回指定日期的指定日期的部分的整数。Datepart() 方法和 Datename() 的方法使用方式类似,只不过 Datename() 方法返回的是一个字符串,而 Datepart() 方法返回的是一个整数数值。该方法有两个参数:

参数1:指定返回指定日期的指定部分的字符串。可以为上图中的日期部分或者缩写。

参数2:指定要操作的日期字符串。

复制代码
select datepart(year,'2017-01-01 10:10:10')    -- 返回 2017
select datepart(yyyy,'2017-01-01 10:10:10')    -- 返回 2017select datepart(month,'2017-01-01 10:10:10')    -- 返回 1
select datepart(mm,'2017-01-01 10:10:10')    -- 返回 1select datepart(quarter,'2017-05-02 10:10:10')        -- 表示一年的第几个季度        返回 2
select datepart(weekday,'2017-02-02 10:10:10')        -- 表示一周的星期几,即一周的第几天,星期日为一周的第一天    返回 5
select datepart(week,'2017-02-02 10:10:10')        -- 表示一年的第几周        返回 5
select datepart(dayofyear,'2017-02-02 10:10:10')        -- 表示一年的第几天        返回 33select datepart(hh,'2017-01-01 10:30:25')    -- 返回 10
复制代码

转载于:https://www.cnblogs.com/huifeidejing/p/6844913.html

相关文章:

“接口”的定义及其与“抽象类”的区别

我们知道一个有抽象方法的类是抽象类,而当一个类中全是抽象方法时,就可以定义为接口(interface) 接口命名通常以“I”开头;接口中的方法默认有public abstract(所以可以省略);接口中…

Linux13-计划任务crontab

目录 一、用户计划任务 1.1、定义用户计划任务的命令crontab 1.2、作业格式 二、系统计划任务cron 三、管理临时文件 3.1、systemd-tmpfiles命令与配置文件 3.2、用法举例 一、用户计划任务 1.1、定义用户计划任务的命令crontab Linux提供了针对周期性作业的crond守护…

Java线程安全 关于原子性与volatile的试验

1. 变量递增试验 1 static /*volatile*/ int shared0;//volatile也无法保证操作的原子性2 static synchronized int incrShared(){//不加synchronized的话,shared最终结果值小于预期3 return shared;4 }5 public static void testIncrShare…

Python学习 day01打卡

1.Python : 是一门解释型 弱类型 高级开发编程语言. 2.第一个Python程序的编写: print ("hell,world") 3.变量:把程序运行过程中的值储存起来,方便后面的程序调用. 4.变量的命名要求: 1,只能是数字或字母或下划线组成; 2,不能是数字开头,也不能全是数字; 3,不能是Pyt…

Window10安装pycocotools

之前在linux系统下安装pycocotools时非常简单,只需: pip install pycocotools 如果在windows下通过以上指令安装会报错,网上查询后都说需要安装C编译器或者VS环境,等等,其实没必要那么麻烦,直接通过一下指令…

有名内部类 匿名内部类

内部类,从名字上就可以看出,是定义在外部类里的类,可以更加详细地说明某个事物的特征,举个例子,就像一个人(把他定义为一个类[外部类]),这个人有大脑、肝脏、心脏等器官,…

Linux14-进程的优先级nice

目录 一、进程优先级和nice的概念 二、显示nice级别 三、更改nice级别 一、进程优先级和nice的概念 CPU管理进程的是按照时间片的方式来划分CPU的资源。CPU可以把1s划分成若干份,轮询时间片。通过设置进程的优先级,让某些重要的进程优先并且长时间获…

ConcurrentHashMap实现原理及源码分析

ConcurrentHashMap是Java并发包中提供的一个线程安全且高效的HashMap实现(若对HashMap的实现原理还不甚了解,可参考我的另一篇文章HashMap实现原理及源码分析),ConcurrentHashMap在并发编程的场景中使用频率非常之高,本…

Gulp的简单使用

我比较喜欢使用Gulp,因为简单好用! 今天的任务是:使用Gulp来压缩 jQuery源码,各输出一个压缩的和未压缩的版本 第一步:安装 cnpm install gulp --save-dev cnpm install gulp-rename gulp-uglify --save-dev 第二步&…

Mask_RCNN安装与踩过的坑

一、Mask_RCNN下载 https://www.bilibili.com/video/BV1M7411x7is?t629&p5 按照上述教程的话,安装的是ballon例子的Mask_RCNN。这个理解的话,修改Mask_RCNN也就很简单了。 1.2 更新驱动 强烈建议更新驱动,因为以后如果装pytorch的话&…

Lambda表达式的运用(详尽版)

Lambda表达式是Java JDK8发布的最新特性,它极大地简化了定义匿名内部类时要写的代码,使代码变得更加简洁紧凑。 我们知道定义匿名内部类时要紧跟创建对象,接着要实现接口或重写父类中的抽象方法,例如: public interfa…

Linux15-SELinux

目录 一、查看和配置SELinux生效 二、SELinux上下文 2.1、查看SELinux上下文 2.2、semanagerestorecon命令更改SELinux上下文 三、SELinux布尔值 四、SELinux故障排除 Security Enhanced Linux(SELinux)是一个额外的系统安全层,是一种强…

Java学习(三)JSP学习1

一、 理解JSP技术 JSP全名为Java Server Pages,中文名叫java服务器页面,其根本是一个简化的Servlet设计,它 是由Sun Microsystems公司倡导、许多公司参与一起建立的一种动态网页技术标准。JSP技术有点类似ASP技术,它是在传统的网…

通过Java代码实现图片的放大和缩小

本文介绍的例子在Android安卓手机上测试通过。 先看看效果吧。可以看到这个开发好的安卓应用有三个按钮:Zoom In缩小图片,Zoom Out放大图片和Save保存。 初始页面: 可以在左边边框自由移动图片,图片下面的调试界面debug screen会显…

ProxyError: Conda cannot proceed due to an error in your proxy configuration

右键网络---->属性---->左下角的Internet选项---->链接---->局域网设置 将所以的对号去掉

Java访问权限(详尽版)

Java中的访问权限一共有四种:public 、protected 、 默认的 、private(访问范围由大到小): 先说public和private这两种,因为这两种最容易理解: public:在整个项目中都可以被访问,无…

suse11sp4配置vnc显示gnome

目录 一、suse11sp4配置vnc默认显示xterm 二、suse11sp4配置vnc显示gnome桌面 一、suse11sp4配置vnc默认显示xterm 今天给一台比较老的服务器配置vnc服务,操作系统为suse11sp4。该服务器已经安装了gnome界面和vnc。vncpasswd设置密码,vncserver :1设置…

ubuntu18.04安装CUDA10.0

1、更新驱动 对于CUDA10.0,要求驱动版本大于410.48,因此首先要更新驱动 ubuntu-drivers devices(查看所有驱动) sudo ubuntu-drivers autoinstall(自动安装最适合的驱动) 查看驱动版本 nvidia-smi 2、下载…

运行时异常 检查时异常

Throwable是Java程序中所有异常对象的根基类,而Throwable是从Object类直接继承来的, Throwable可分为error(错误)和 Exception(异常)。error表示的是JDK出了问题,与写的代码无关;而E…

Atitit. Attilax企业框架 AEF的发展里程总结

Atitit. Attilax企业框架 AEF的发展里程总结 1. Attilax企业框架and框架发展思想 1 2. AEF框架 2 2.1. 多语言支持,涉及的语言 java ,c# php python js c 2 2.2. 业务模块支持 2 2.3. 技术组件支持 2 2.4. 平台化支持 2 2.5. 插件化支持 2 3. AEF框架发展里程 3 3.1…

1.3创建项目「深入浅出ASP.NET Core系列」

控制台创建项目 dotnet new --help 使用控制台采集项目,务必要熟练使用命令,--help是命令帮助的指明灯,在你无法google的时候,可以离线状态最快的帮助到你。 根据模板名称,我们可以创建各种模板,比如 dotne…

Linux16-防火墙与firewalld

目录 一、netfilter与firewalld 二、firewalld与firewall-cmd、firewall-config 2.1、预定义区域 2.2、预定义服务 2.3、firewall-cmd和firewall-config配置工具 2.4、富规则rich-rule 一、netfilter与firewalld linux内核有个防火墙模块netfilter,它是一个 …

throws throw 自定义异常

我们知道当程序遇到异常时除了用try-catch-finally来捕获异常外,还可以用throws和throw去抛出异常,使用异常处理可以定位问题所在处,方便修改程序代码: 例如利用try-catch-finally来捕获异常: public class Test{pub…

配置hadoop集群一

花了1天时间最终把环境搭建好了。整理了一下,希望对想学习hadoop的有所帮助。资料下载:http://pan.baidu.com/s/1kTupgkn包括了linux虚拟机。jdk, hadoop1.0环境搭建准备工作:hadoop_master 192.168.50.158hadoop_slave 192.168.50.136网络…

将前台日期格式转成与数据库日期格式相对应,后台java转数据库日期格式

前台到后台java时data日期类型的转化 在实体类中用DataTimeFormat,这样设置即使传过来是空的字符串也是可以转的,要和前面传过来的格式一致,如 XmlElement(name"BeginDate") DateTimeFormat(pattern"yyyy-MM-dd") privat…

Ubuntu18.04安装cudnn

下载Cudnn cudnn下载版本要与cudn版本相对应。笔者cudn为10.0,则cudnn选7.65。下载地址: https://developer.nvidia.com/rdp/cudnn-archive 下载for Linux这个。 编译 解压后运行以下命令: sudo cp cuda/include/cudnn.h /usr/local/cuda…

Linux17-磁盘分区、文件系统、逻辑卷管理LVM

目录 一、磁盘分区、文件系统、永久挂载 1.1、MBR分区方案 1.2、使用fdisk、mkfs、partprobe、blkid、lsblk等命令管理MBR分区 1.3、swap分区 1.4、GPT分区方案、使用gdisk管理GPT分区 二、逻辑卷LVM(Logical Volume Management) 2.1、物理卷PV、…

javascript基础 之 json

1&#xff0c;json是用于存储和传输的数据格式 全称&#xff1a;JSON 英文全称 JavaScript Object Notation json转化为javascript的规则&#xff1a; 数据为 键/值 对。数据由逗号分隔。大括号保存对象方括号保存数组<body> <p id"hehe"></p> <…

List常用方法总结 遍历集合的方法

List接口继承Collection接口&#xff0c;该接口属于数据结构中的线性结构&#xff0c;用户可以根据元素的整数索引来访问元素&#xff0c;换句话说就是List集合是按照存储的顺序保存的&#xff0c;且从0开始数&#xff0c;说白了就是就相当于一个数组&#xff0c;不同的是数组要…

ubuntu下载安装MaskRCNN-benchmark

在window下&#xff0c;配个环境&#xff0c;一堆错误&#xff0c;一周多都没解决。换到ubuntu下&#xff0c;不到一天就配好了 强烈建议直接去ubuntu下配置&#xff0c;千万别在window环境下配置。 一、下载anaconda&#xff0c;创建虚拟环境 下载anaconda的步骤读者可以去…