Oracle常用函数汇总

在Oracle OCP考试中,相当一部分知识点涉及到对于Oracle常见函数的考查。尽管Oracle官方文档SQL Language Reference中Functions一章内列举了所有Oracle自带函数,但如果要系统的看一遍,还是要花费相当的精力,更何况还是英文呢。如果碰到一个不熟悉的,就查一下,不经常用,又很容易遗忘。下面就对Oracle常见函数做个整理,方便以后查询。

一、 大小写转换函数

1. LOWER函数

LOWER函数将字符以小写形式输出。其语法为LOWER(char)。

例如:

SQL> select lower(100+100),lower(sysdate),lower('HELLO') from dual;

LOW LOWER(SYS LOWER
---    ---------      -----
200  25-sep-14    hello

注意:返回的均是字符类型,在执行LOWER函数之前先计算数据和日期表达式,并隐式转换为字符数据。

2. UPPER函数

UPPER函数将字符以大写形式输出。其语法为UPPER(char)。

例如:

SQL> select upper('hello world') from dual;

UPPER('HELL
-----------
HELLO WORLD

3. INITCAP函数

INITCAP函数将字符串中每个单词的第一个字母大写,而该单词的剩余字母小写。

例如:

SQL> select initcap('hello WORLD! that is funny!') from dual;

INITCAP('HELLOWORLD!THATISF
---------------------------
Hello World! That Is Funny!

二、 字符操作函数

1. CONCAT函数

CONCAT函数用于连接两个字符串。有两个参数,语法为CONCAT(s1,s2)。

例如:

SQL> select concat('hello','world') from dual;

CONCAT('HE
----------
helloworld

SQL> select concat(concat(ename,'''s job is '),job) from emp where empno=7788;

CONCAT(CONCAT(ENAME,'''SJOBIS
-----------------------------
SCOTT's job is ANALYST

2. LENGTH函数

LENGTH函数返回字符串的字符数,包括空格,制表符和特殊字符。其语法为LENGTH(s)。

例如:

SQL> select length('hello world!') from dual;

LENGTH('HELLOWORLD!')
---------------------
12

3. LPAD和RPAD函数

LPAD和RPAD函数分别被称为左填充和右填充函数。它们分别在给定字符串左边或右边填充指定数量的字符。其语法为LPAD(s,n,p)和RPAD(s,n,p),其中s表示源字符串,n表示返回字符串的最终长度,p指定用于填充的字符串。注意:如果参数n小于或者等于源字符串s的长度,就不会添加任何字符,此时只返回源字符串s的前n个字符。p默认为空格。

例如:

SQL> select lpad('hello',10,'*'),lpad('hello',10,'*#'),lpad('hello',10),lpad('hello',4,'*') from dual;

LPAD('HELL LPAD('HELL LPAD('HELL LPAD
----------     ----------      ----------    ----
*****hello  *#*#*hello        hello    hell

SQL> select rpad('hello',10,'*'),rpad('hello',10,'*#'),rpad('hello',10),rpad('hello',4,'*') from dual;

RPAD('HELL RPAD('HELL   RPAD('HELL RPAD
----------     ----------       ----------     ----
hello*****  hello*#*#*   hello            hell

4. TRIM函数

TRIM函数从字符串的开头或者结尾删除一些字符。其语法为TRIM([trailing|leading|both] trimstring from s)。其中

TRIM(s)删除输入字符串两边的空格

TRIM(trailing trimstring from s)从字符串s的结尾删除所有trimstring(如果存在的话)。

TRIM(leading trimstring from s)从字符串s的开头删除所有trimstring。

TRIM(both trimstring from s)从字符串s的开头和结尾删除所有trimstring。

SQL> select trim(both '*' from '***hello****') from dual;

TRIM(
-----
hello

SQL> select trim(trailing '*' from '***hello****') from dual;

TRIM(TRA
--------
***hello

SQL> select trim(leading '*' from '***hello****') from dual;

TRIM(LEAD
---------
hello****

注意:trimstring只能是一个字符。

SQL> select trim(leading '*!' from '*!*!hello') from dual;
select trim(leading '*!' from '*!*!hello') from dual
*
ERROR at line 1:
ORA-30001: trim set should have only one character

5. INSTR函数(In-string)

INSTR函数确定搜索字符串在给定字符串中的位置。它返回数字位置,如果搜索字符串不存在,则该函数返回0。其语法为INSTR(source string,search string,[search start position],[nth occurrence])。其中,后两个参数是可选的,search start position的默认值是1,即source string的开头。nth occurrence的默认值是1,即第一次出现。

例如:

SQL> select instr('1*3*5*7*9','*',-3,2) from dual;

INSTR('1*3*5*7*9','*',-3,2)
---------------------------
                                 4

SQL> select instr('1*3*5*7*9','*') from dual;

INSTR('1*3*5*7*9','*')
----------------------
                           2

SQL> select instr('1*3*5*7*9','*',2) from dual;

INSTR('1*3*5*7*9','*',2)
------------------------
                             2

6. SUBSTR函数(Substring)

SUBSTR函数从给定源字符串中给定的位置开始,提取指定长度的子字符串。其语法为SUBSTR(source string,start position,[number of characters to extrace])。最后一个参数可选,倘若没有指定,默认从start position到source string结尾的字符数。

例如:

SQL> select substr('1*3*5*7',3) from dual;

SUBST
-----
3*5*7

SQL> select substr('1*3*5*7',3,2) from dual;

SU
--
3*

SQL> select substr('1*3*5*7',-3,2) from dual;

SU
--
5*

7. REPLACE函数

REPLACE函数用替换项取代源字符串中出现的所有搜索项。其语法为REPLACE(source string,search item,[replacement term])。replacement term默认为空字符。

例如:

SQL> select replace('1*3*5*7','*','->') from dual;

REPLACE('1
----------
1->3->5->7

SQL> select replace('1*3*5*7','*') from dual;

REPL
----
1357

三、 数字函数

1. 数字round函数

ROUND函数依据指定的小数精度对数值进行四舍五入运算。其语法为ROUND(source number,decimal precision)。decimal precision参数指定舍入的精度。默认是0,即对源数字四舍五入到整数。如果指定的小数精度n为正数,则要舍入的有效数字在小数点右边(n+1)个位置。如果n为负数,则要舍入的有效数字在小数点左边n个位置。

例如:

SQL> select round(145.78,-1) from dual;

ROUND(145.78,-1)
----------------
150

SQL> select round(145.78) from dual;

ROUND(145.78)
-------------
146

SQL> select round(145.78,1) from dual;

ROUND(145.78,1)
---------------
145.8

2. TRUNC函数(Truncate)

TRUNC函数依据指定的小数精度对数值进行截取运算。其语法为TRUNC(source number,decimal precision)。

例如:

SQL> select trunc(145.78,-1) from dual;

TRUNC(145.78,-1)
----------------
140

SQL> select trunc(145.78) from dual;

TRUNC(145.78)
-------------
145

SQL> select trunc(145.78,1) from dual;

TRUNC(145.78,1)
---------------
145.7

3. MOD函数(Modulus)

MOD函数返回除法运算的余数。

例如:

SQL> select mod(5,2) from dual;

MOD(5,2)
----------
           1

SQL> select mod(5.2,2.2) from dual;

MOD(5.2,2.2)
------------
             .8

四、 日期函数

1. MONTHS_BETWEEN函数

MONTHS_BETWEEN函数返回两个日期参数之间月数的数值。其语法为MONTHS_BETWEEN(date1,date2)。该函数计算date1和date2之间月份的差值(每月31天),即date1-date2。返回值可能由整数和小数部分组成。其中,整数表示这两个日期之间相差的月数。小数部分表示剩余的天数和时间,以31天的月份为基础。

例如:

SQL> select months_between(sysdate,sysdate-31) from dual;

MONTHS_BETWEEN(SYSDATE,SYSDATE-31)
----------------------------------
                                          1

SQL> select months_between('2-MAR-2014','1-FEB-2014') from dual;

MONTHS_BETWEEN('2-MAR-2014','1-FEB-2014')
-----------------------------------------
                                    1.03225806

SQL> select 1/31 from dual;

1/31
----------
.032258065

--可以看出小数部分是以31天为基础的。

2. ADD_MONTHS函数

ADD_MONTHS函数语法为ADD_MONTHS(date,number of months),即计算指定月份添加到指定date后的日期。月数可以为负。

例如:

SQL> select add_months('1-MAR-2014',1) from dual;

ADD_MONTH
---------
01-APR-14

SQL> select add_months('1-MAR-2014',2.9) from dual;

ADD_MONTH
---------
01-MAY-14

SQL> select add_months('1-MAR-2014',-2.9) from dual;

ADD_MONTH
---------
01-JAN-14

3. NEXT_DAY函数

NEXT_DAY返回在指定日期后下一次出现星期几的日期。其语法为NEXT_DAY(start date,day of the week)。函数计算在start date之后day of the week下一次出现的日期。day of the week可以是字符值或者整数值。其中,字符值至少是星期名称的前三个字符,例如,星期日可以表示为sun,sund,sunda或者Sunday。对于整数,1表示星期日,2表示星期一,以此类推。

例如:19-SEP-2014是周五

SQL> select next_day('19-SEP-2014',5) from dual;

NEXT_DAY(
---------
25-SEP-14

SQL> select next_day('19-SEP-2014','tue') from dual;

NEXT_DAY(
---------
23-SEP-14

SQL> select next_day('19-SEP-2014','SUNDAY') from dual;

NEXT_DAY(
---------
21-SEP-14

4. LAST_DAY函数

LAST_DAY函数提取指定日期所属的月,并计算该月最后一天的日期。其语法为LAST_DAY(date)。

例如:

SQL> select last_day('19-SEP-2014') from dual;

LAST_DAY(
---------
30-SEP-14

5. 日期ROUND函数

日期ROUND函数依据指定的日期精度格式对日期进行舍入运算。其语法为ROUND(source date,[date precision format]).source date表示任意日期。date precision format包括世纪(CC),年(YYYY),季度(Q),月(MM),星期(W),日(DD),时(HH)和分(MI)。

如果日部分大于16,则会入到下一个月,否则舍到当月。如果月在1和6之间,则会舍到当年开头的日期,否则入到下一年开头的日期。

例如:

查询的时间为:2014-09-26 04:44:38

SQL> select round(sysdate) day,round(sysdate,'w')week,round(sysdate,'month')month,round(sysdate,'year')year from dual;

DAY          WEEK         MONTH       YEAR
---------     ---------     ---------      ---------
26-SEP-14 29-SEP-14  01-OCT-14  01-JAN-15

因为查询时间是4点,没有查过12点,故DAY是当天。因为本月1号是周一,WEEK返回的是查询时间起,下一个周一的日期,即29-SEP-14。因为查询时间是26号,超过16号,故MONTH需入到下一个月。因为查询时间是9月,超过6月,故入到下一年。

6. 日期TRUNC函数

日期TRUNC函数依据指定的日期精度格式对日期进行截取运算。其语法为TRUNC(source date,[date precision format])。date precision format指定截取的精度,默认的截取精度是日。这就意味着将source date的所有时间都设置为00:00:00(00时、00分和00秒)。在月级别上的截取将source date的日期设置为该月的第一天。年级别的截取返回当年开头的日期。

例如:

SQL> select trunc(sysdate) day,trunc(sysdate,'w')week,trunc(sysdate,'month')month,trunc(sysdate,'year')year from dual;

DAY           WEEK        MONTH      YEAR
---------     ---------     ---------     ---------
26-SEP-14  22-SEP-14 01-SEP-14 01-JAN-14

唯一需要注意的是WEEK,因为本月1号是周一,WEEK返回的是本周周一的日期。

 

转载于:https://www.cnblogs.com/ivictor/p/3994478.html

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

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

相关文章

直方图python高度_python – 子图中直方图的动画

normed 直方图的True参数使直方图绘制分布的密度.从the documentation开始: normed : boolean, optional If True, the first element of the return tuple will be the counts normalized to form a probability density, i.e., n/(len(x)dbin), i.e., the integra…

【java设计模式之Command(菜单命令) 】

Command模式是最让我疑惑的一个模式,我在阅读了很多代码后,才感觉隐约掌握其大概原理,我认为理解设计模式最主要是掌握起原理构造,这样才对自己实际编程有指导作用.Command模式实际上不是个很具体,规定很多的模式,正是这个灵活性,让人有些confuse.    Command定义  不少C…

经典的01背包问题

01背包问题具体例子: 假设现有容量10kg的背包,另外有3个物品,分别为a1,a2,a3。物品a1重量为3kg,价值为4;物品a2重量为4kg,价值为5;物品a3重量为5kg,价值为6。将哪些物品放入背包可使得背包中的总价值最大? 这个问题有两种解法,动态规划和贪婪算法。本文仅涉及动态…

代码设置Shape和Selector

开发中经常需要使用Shape和Selector,如果每个都用xml设置的话,会占用apk大小,同时命名多了也会混乱,使用代码来设置会方便很多。 需要用到2个类:GradientDrawable和StateListDrawable 相关API: setColor(rg…

Kubernetes:全面了解 Deployment

本文为作者的 Kubernetes 系列电子书的一部分,电子书已经开源,欢迎关注,电子书浏览地址:https://k8s.whuanle.cn【适合国内访问】https://ek8s.whuanle.cn 【gitbook】Deployment 是 Kubernetes 提供的一种自我修复机制来解决机器…

史上最冤!美国原子弹之父被骂了9年!最后他上台领奖,竟一把推开了总统.........

全世界只有3.14 % 的人关注了爆炸吧知识原子裂变不及人心善变“漫天奇光异彩,犹如圣灵逞威,祇有千只太阳,始能与它争辉。”1945年7月15日,奥本海默注视着远处的蘑菇云,想起了《摩诃婆罗多经:福者之歌》中的…

python实例化是什么意思_Python中实例化class的执行顺序示例详解

前言 本文主要介绍了关于Python实例化class的执行顺序的相关内容,下面话不多说了,来一起看看详细的介绍吧 Python里对类的实例化时有怎样的顺序 一般来说一个类里面有类变量和方法,比如我们定义一个名为A的类 class A(): bar "my lover…

IIS集成模式和经典模式 系统部署的不同

http://blog.csdn.net/byondocean/article/details/7074772转载于:https://www.cnblogs.com/mmnyjq/p/3298193.html

贪心算法

贪心算法 一、定义 什么是贪心算法呢?所谓贪心算法是指,在对问题求解时,总是做出在当前看来最好的选择。也就是说,不从整体最优解出发来考虑,它所做出的仅是在某种意义上的局部最优解。 贪心算法不是对所有问题都能得到整体最优解,但对范围相当广泛的许多问题都能产生整体…

spring 基于java的配置

2019独角兽企业重金招聘Python工程师标准>>> 7.10 Classpath scanning and managed componets 文档地址: http://docs.spring.io/spring/docs/current/spring-framework-reference/htmlsingle/#beans-classpath-scanning 本章中大部分例子是用xml来指定配置元数据,以…

如何提升个人专业能力

1.写文章,多发表个人见解,增加个人思考机会; 2.大量看书,自学,但一定要选好书;3.多和圈里高手交流,听君一席话,胜读十年书,遇到不懂的多请教;4.建立个人文件管…

WPF 实现3D翻转倒计时控件~

WPF开发者QQ群&#xff1a; 340500857由于微信群人数太多入群请添加小编微信号yanjinhuawechat 或 W_Feng_aiQ 邀请入群需备注WPF开发者 PS&#xff1a;有更好的方式欢迎推荐。接着上一篇倒计时控件01—代码如下一、创建 NumberCardControl.xaml代码如下。<UserControl x:Cl…

python逐行读取excel_python对execl 处理操作代码

1. 读取execl 1.前提需要安装xlrd模块&#xff0c;这个在网上可以找安装教程&#xff0c;这里就不写了 2. 打开表格 3. 读取表格的sheet 4. 按行读取数据或者列读取数据或者单元格读取数据 实际操作&#xff1a; import xlrd import xlwt from xlutils.copy import copy def in…

Android之Android studio基本调试和快捷键

第一种调试方法: 如果APP是单进程,直接debug运行,如下图 第二种调试方法: 第二种就是调试当前已经处于运行状态下的App,这也是我们用的更多的一种调试手段,即 Attach debugger to Android process 。点击运行按钮右侧第三个按钮,弹出 Choose Process 窗口,选择对应的进…

Windows 2008 R2安装DHCP服务器问题及解决方法

错误一&#xff1a;0x80074E6F 指定的服务器已在目录服务中造成此错误的原因是DHCP服务器没有正常卸载&#xff0c;第二次安装就会报如下图错误解决方法1.卸载DHCP服务器2.重启服务器3.打开adsiedit.msc4.如下图展开到 CNNetServices5.删除CNYour ServerName6.重新安装DHCP服务…

免费动态域名解析

DDNS 顾名思义就是动态域名解析&#xff0c;让域名绑定在动态 IP 上&#xff0c;比如拨号上网的 ADSL 用户。国内的 DDNS 服务有花生壳和 3322.org 这种提供商&#xff0c;我一直在用花生壳的免费 DDNS&#xff0c;可是近期情况非常糟糕&#xff0c;我到北京以来&#xff0c;就…

2021 年 CNCF 和开源速度的年终报告

深入了解开发速度最快的项目&#xff0c;可以很好地表明哪些领域正在起飞&#xff0c;哪些平台可能在未来几个月和几年内取得成功。如何评估一个项目的活跃度&#xff0c;通常从这几个方面, commits, contributions, issues 和 pull requests&#xff0c;而使用气泡图是一种很巧…

清华姚班毕业生不配自信?张昆玮在豆瓣征女友,却被网友群嘲......

全世界只有3.14 % 的人关注了爆炸吧知识不要看脸好好说话没想到&#xff0c;清华也有被瞧不起的一天。上周&#xff0c;山西某网友在D瓣上发布了一则征友贴&#xff1a;总结下来&#xff0c;就是一句话&#xff1a;俺&#xff0c;一介俗人&#xff0c;二本教师&#xff0c;兼职…

转: javascript技术栈

http://www.infoq.com/cn/articles/state-of-javascript-2016