abs函数的使用方法 oracle_SQL Server 常用函数使用方法

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

算法简要说明:

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

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

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

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

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

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

select upper('abc') -- 返回 ABCselect lower('ABC') -- 返回 abcselect upper('123') -- 返回 123

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

15、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

16、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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

21、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

22、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
d506cac66f4faaeb0c34d7156e0b2fc1.png

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

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
68f340c2ab2ade8ff3f96b84a33b7639.png

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

select getdate()
9befed11e0531cb523f954ede6d91c40.png

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

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

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

25、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

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

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

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

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

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

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

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

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

28、Coalesce():返回所有参数中的第一个非空(not null)表达式。该方法最多可以有 n 个参数,但是最少要有两个参数。

SELECT COALESCE('abc','') -- 返回 abc SELECT COALESCE(NULL,'') -- 返回 空字符串http://SELECT COALESCE(null,null,'123','abc') -- 返回 123

PS:这个函数是返回第一个非空的值,所以参数里面必须最少有一个非空的值。

29、ISNull():判断指定的表达式一是否为空(null),如果为空则返回表达式二的值,否则返回表达式一的值,类似于C#中的三元运算符。该方法有两个参数:

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

参数2:指定要操作的表达式二。

select isnull('','123') -- 返回 空字符串 select isnull(null,'123') -- 返回 123 select isnull('123','abc') -- 返回 123 select isnull(null,null) -- 返回 null

30、Convert():数据类型转换。该方法有三个参数:

参数1:指定要转换后的数据类型。

参数2:指定要转换的表达式,可以是字段或表达式

参数3:转换后的格式,如日期型转换后有很多种格式,yyyy/mm/dd 等,这个参数可以省略。

CONVERT(varchar(10),'1,2,3,') --返回 '1','2','3'

还有就是这我总结出了一些架构视频资料和互联网公司java程序员面试涉及到的绝大部分面试题和答案做成了文档和架构视频资料还有完整高清的java进阶架构学习思维导图免费分享给大家(包括Dubbo、Redis、Netty、zookeeper、Spring cloud、分布式、高并发等架构技术资料),希望能帮助到您面试前的复习且找到一个好的工作,也节省大家在网上搜索资料的时间来学习。

870b7810d2e1310dfa87c189a2abc3b7.png

资料领取方式:关注 私信关键字【资料】即可免费获取!!!

如果您喜欢本文章,可以点击关注,每天将有更多精彩文章与您分享!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/299399.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

高考落榜怎么办,奉劝学弟学妹们一些事情,请一定要擦亮眼睛

在目前这个社会情况Java技术是当前社会的一个热门专业,无论是pc端还是移动端对java的需求都是最多的,大学生学java正好顺应时代的发展,不仅有钱途还有前途,Java也适合零基础的人学习。 最近看见一句话 高考不努力,学习…

神仙打架!一人公开单挑全欧洲数学家,却惨遭4位数学家大反转,66年的难题被一晚破解......

全世界只有3.14 % 的人关注了青少年数学之旅两点之间直线最短,这家喻户晓的数学名言,就算是学渣也能倒背如流。但学渣们不知道的是,这条直线并不是最快的。为了让学渣们真正理解这句话,今天,超模君决定科普一波起源关于…

基于事件驱动架构构建微服务第4部分:repositories

原文链接:https://logcorner.com/building-microservices-through-event-driven-architecture-part4-repositories/在本文中,我将实现Repositories的命令端。存储库属于Clean架构的接口适配器在这一步中,我将开始实现基础设施的命令端&#x…

小松

之前做过一次小小的介绍(没看过的请参看此文:闲话小松),相信不少老朋友应该都知道我是谁了。还不认识我的朋友可以称呼我小松(这名号有年头了,听习惯了^_^),当然你喜欢怎么喊都成:)偶是个是理想主义的倡导者&#xff0…

vlan后 出现 outlook 正在试图从服务器检索数据

vlan后 出现 outlook 正在试图从服务器检索数据 cisco vlan outlook 正图试从Microsoft Exchange Server 检索数据。cisco 3750 vlan outlook is retrieving data from Microsoft Exchange Server mail.abc.com 最近对公司的网络按需要划分了基出802.1q的VLAN,…

二面京东,面试官直接问我JVM,我心里一阵暗爽~

二面京东,面试官直接问我JVM,我心里一阵暗爽~简直了,hhhh明人不说暗话,直接进入主题!!!一、什么是JVM二、JAVA代码编译和执行过程类加载机制类执行机制三、JVM内存管理和垃圾回收垃圾回收按照基…

最后的代课老师———漆红玉[转]

1月31日凌晨6点我们从渭源县城出发,天还未亮。1月的甘肃干冷干冷的,我们是在半路上接的漆老师,刚开始我以为是寇筱茜老师的一个熟人,路上寇老师才和我说漆老师也是代课老师。寇筱茜老师有一句名言:每一个代课老师都有一…

ae渲染出现错误是什么问题_[Switch]解决OPENWRT路由,使用UU加速器等出现相同IP,DNS解析错误问题...

本文在之上添加DNS解析错误的解决方案解决 NS openwrt路由器 开腾讯 UU之类的加速器无法上网的问题​tieba.baidu.com将子网掩码转换为二进制,即为11111111.11111111.0.0,1有16位,令x16;IP地址若为aaa.bbb.ccc.ddd,设置…

程序员从入门到升级,或许可以看一看这几个公众号

全世界只有3.14 % 的人关注了青少年数学之旅快节奏的现代社会中,每个人都疲于奔命,“丧、累、太难了”已成为成年人的生活主题。难得的闲暇时间,公众号是不可或缺的消遣方式。但我们被海量数据淹没,越来越多的公众号只是消耗情绪&…

C# 向Main函数传递参数(程序启动时传递参数)

代码 staticvoidMain(string[] args) { Application.EnableVisualStyles(); Application.SetCompatibleTextRenderingDefault(false);if(args.Length!0) { Application.Run(newF_WebIE(args[0])); }else{ Application.Run(newF_WebIE(null)); } }注意:不能把 参数 s…

12c oracle 修改内存_关于Oracle数据库12c 新特性总结

概述今天主要简单介绍一下Oracle12c的一些新特性,仅供参考。参考:http://docs.oracle.com/database/121/NEWFT/chapter12102.htm#NEWFT003https://docs.oracle.com/database/121/NEWFT/chapter12101.htm#NEWFT3481、不可见字段(Invisible columns)在 12c…

华为面试官问我:你真的明白Java垃圾回收器吗?我生气了!!(︶︿︶)

[第一阶段]:串行垃圾回收器:jdk1.3.1之前Java虚拟机仅仅只支持Serial收集器 [第二阶段]:并行垃圾回收器:随着多核的出现,Java引入了并行垃圾回收器,充分利用多核性能提升垃圾回收效率 [第三阶段]&#xff1…

看OpenCV如何在python中实现图像检测!

全世界只有3.14 % 的人关注了爆炸吧知识在我们生活中,常见的图像处理软件有Adobe Photoshop、Adobe Illustrator等。然而,并非只有软件才能实现图像处理,通过编程手段也是能实现的!今天,小天将要带着大家走进计算机视觉…

dotnet 基于 dotnet format 的 GitHub Action 自动代码格式化机器人

是不是大家也会觉得代码审查里面审查代码格式化问题是无意义的,但是不审查又觉得过不去?是否有个专门的工具人,用来协助修复代码格式化的问题?本文来安利大家一个特别好用的方法,使用 dotnet 完全开源的专业格式化工具…

[导入]ASP.NET MVC的WebSite模式(with mvc membership)

一直极其讨厌web application,感觉不干净,不符合个人喜好完美纯净的代码的癖好,再加上不是单页程序集,性能也大打折扣。所以这次在决定用asp.net MVC写这个网站的时候花了一点时间移到Web site模式下面来。 其实不是很麻烦,修改We…

学妹面试拼刀刀被问Java策略模式是什么鬼?哈哈哈哈

学妹面试拼刀刀被问Java策略模式是什么鬼?哈哈哈哈 学妹跟我讲怎么机智面对的 我呆了! 🧾1.策略模式到底是什么鬼捏???👀 策略模式属于对象的行为模式。其用意是针对一组算法,将每一…

基于Visual C++2010与windows SDK fo windows7开发windows7平台的tabletpc应用(1)-手写数学公式输入...

搭建好Visual C2010与windows SDK fo windows7的开发平台以后, 小试牛刀,检验下开发windows7的下的tabletpc应用,这个东西财务记账比较多, 大家先看效果,然后讲解详细代码 详情请见代码注释 // Windows 头文件 #includ…

你所阅读的,决定你是什么样的人

全世界只有3.14 % 的人关注了爆炸吧知识真正决定人与人之间的差距的,其实是我们对事物的见识与内心的格局,见识的深浅决定人生的深浅,格局的大小决定了人生之路是宽是窄。今天给大家推荐几个有深度、有想法的公众号,希望能够给你带…

下图为双总线结构机器的数据通路_海康机器人为物流加码:进击吧,双11新“打工人”...

今年的双11开启了迄今最长“战线”据国家邮政局初步预计,11月1日-16日全行业处理的邮(快)件业务量将达57.8亿件同比增长47%左右双11期间业务量将达29亿件比去年同期增长28%庞大的业务量和超快的物流速度,离不开智能终端、物联网、大数据等多重技术的支持…

设计模式之状态

状态模式介绍状态模式是一种行为设计模式,让你能在一个对象的内部状态变化时改变其行为,使其看上去就像改变了自身所属的类一样。根据状态不同,行为也不同状态模式描述的是一个行为下的多种状态变更,比如我们最常见的一个网站的页…