zoukankan      html  css  js  c++  java
  • Oracle 之 常用函数

      SQL语句根据参数的不同,分为单行函数 和 多行函数。

      [1] 单行函数:输入是一行,输出也是一行;

      [2] 多行函数:输入多行数据,输出一个结果。

      在执行时,单行函数是检索一行处理一次,而多行函数是将检索出来的数据分成组后再进行处理。

      根据函数参数不同,SQL函数又分为数值函数、字符函数、日期函数、转换函数、聚集函数等多种。

    1、数值函数:函数的输入、输出都是数值型数据

      单行数字函数操作数字数据,执行数学和算术运算。所有函数都有数字参数并返回数字值。所有三角函数的操作数和值都是弧度而不是角度,oracle没有提供内建的弧度和角度的转换函数。

    1.1 ABS(n) :返回n的绝对值

    3.2 ACOS(n) :反余玄函数,返回-1到1之间的数。n表示弧度

      select ACOS(-1) pi,ACOS(1) ZERO FROM dualPI ZERO3.14159265 0

    3.3 ASIN(n) :反正玄函数,返回-1到1,n表示弧度

    3.4 ATAN(n) :反正切函数,返回n的反正切值,n表示弧度。

    3.5 CEIL(n) :返回大于或等于n的最小整数。

    3.6 COS(n) :返回n的余玄值,n为弧度

    3.7 COSH(n) :返回n的双曲余玄值,n 为数字。

      select COSH(<1.4>) FROM dualCOSH(1.4)2.15089847

    3.8 EXP(n) :返回e的n次幂,e=2.71828183.

    3.9 FLOOR(n) :返回小于等于n的最大整数。

    3.10 LN(n) :返回以e为底,n的对数,n必须大于0

    3.11 LOG(m, n): 返回以m为底n的对数

    3.12 MOD(m, n) :返回m除以n的余数

    3.13 POWER(m,n): 返回m的n次方

    3.14 ROUND(m [, n])

      对m进行四舍五入(当n大于0时,将m四舍五入到小数点右边n位;当n省略时,对m取整;当n小于0时,将m四舍五入到小数点左边n位;n2必须是整数)。

      select ROUND(12345,-2),ROUND(12345.54321,2) FROM dual

      ROUND(12345,-2) ROUND(12345.54321,2)12300 12345.54

    3.15 SIGN(n) :判断n的正负(n大于0返回1;n等于0返回0;n小于0返回-1)

    3.16 SIN(n) :返回n的正玄值,n为弧度。

    3.17 SINH(n) :返回n的双曲正玄值,n为弧度。

    3.18 SQRT(n) :返回n的平方根,n为弧度

    3.19 TAN(n): 返回n的正切值,n为弧度

    3.20 TANH(n) :返回n的双曲正切值,n为弧度

    3.21 TRUNC(m [, n]) :对m进行截取操作(当n大于0时,将m截取到小数点右边n位;当n省略时,截取m的小数部分;当n小于0时,将m截取到小数点左边n位;n2必须是整数)。

      SQL和PL/SQL中自带很多类型的函数,有字符、数字、日期、转换、和混合型等多种函数用于处理单行数据,因此这些都可被统称为单行函数。这些函数均可用于SELECT,WHERE、ORDER BY、HAVING等子句中,例如下面的例子中就包含了TO_CHAR,UPPER,SOUNDEX等单行函数。

    SELECT ename, TO_CHAR(hiredate,'day,DD-Mon-YYYY') 
    FROM scott.emp 
    WHERE UPPER(ename) Like 'AL%'
    ORDER BY SOUNDEX(ename)

      单行函数也可以在其他语句中使用,如update的SET子句,INSERT的VALUES子句,DELET的WHERE子句,最常用的是在SELECT语句中使用这些函数,所以我们的注意力也集中在SELECT语句中。

    2、字符函数

      单行字符串函数用于操作字符串数据,他们大多数有一个或多个参数,其中绝大多数返回字符串。

    2.1 ASCII(char) :char是一字符串,返回字符串首字符的ASCII码值,它的逆函数是CHR()

      SELECT ASCII('A') BIG_A,ASCII('z') BIG_z FROM emp

      BIG_A BIG_z

      65   122

    2.2 CHR(n):n是一个数值,返回ASCII码值为n的字符

      select CHR(65),CHR(122),CHR(223) FROM emp

      CHR65 CHR122 CHR223

      A     z     B

    2.3 CONCAT(char1, char2) :用于字符串连接,返回char2与char1连接后的字符串

      char1,char2均为字符串,函数将c2连接到c1的后面,如果c1为null,将返回c2.如果c2为null,则返回c1,如果c1、c2都为null,则返回null。它和操作符返回的结果相同。

      select concat('slobo','Svoboda') username from dual

      username

      sloboSyoboda

    2.4 INITCAP(char) :将字符串中每个单词的首字母大写

      char为一字符串。函数将每个单词的首字母大写其它字母小写返回。单词由空格,控制字符,标点符号分隔。

      select INITCAP('veni,vedi,vici') Ceasar from dual

      Veni,Vedi,Vici

      select INITCAP('veni       vedi.vici') Ceasar from dual;

      Veni    Vedi.Vici

    2.5 INSTR(char1, char2,[ m[, n]]) :返回指定字符串char2在字符串char1中的位置,m表示其实搜索位置,n表示char2在char1中出现的次数

      char1,char2均为字符串,m,n为整数。当没有发现需要的字符时返回0,如果m为负数,那么搜索将从右到左进行,但是位置的计算还是从左到右,m和n的缺省值为1.

      select INSTR('Mississippi','i',3,4) from dual ;  11

      select INSTR('Mississippi','i',-2,3) from dual;  2

    2.6 INSTRB(char1, char2,[ m[, n])

      与INSTR()函数一样,只是他返回的是字节,对于单字节INSTRB()等于INSTR()

    2.7 LENGTH(char)char为字符串,返回char的长度,如果char为null,那么将返回null值。

      select LENGTH('Ipso Facto') ergo from dual;

      ergo  10

    2.7 LENGTHB(char) :与LENGTH()一样,返回字节。

    2.8 LOWER(char):返回char的小写字符,经常出现在where子串中

      select LOWER(colorname) from itemdetail WHERE LOWER(colorname) LIKE '%white%';

      Winter  white

    2.9 LPAD( char1, n, [ char2 ] )

      char1是需要粘贴字符的字符串

      n 是返回的字符串的长度,如果这个长度比原字符串的长度要短,lpad函数将会把字符串截取成长度 n;

      char2是个可选参数,这个字符串是要粘贴到char1的左边,如果这个参数未写,lpad函数将会在 char1 的左边粘贴空格。

      例如:

      LPAD('tech', 7);       将返回' tech'

      LPAD('tech', 2); 将返回'te'

      LPAD('tech', 8, '0'); 将返回'0000tech'

      LPAD('tech on the net', 15, 'z'); 将返回 'tech on the net'

      LPAD('tech on the net', 16, 'z'); 将返回 'ztech on the net'

    2.10 RPAD( char1, n, [ char2 ] )

      与LPAD函数类似,用来格式化输出的结果。当输出结果位数少于规定的位数,使用LPAD函数在结果的左边添加自定义字符补齐位数, 使用RPAD函数在结果的右边添加自定义字符补齐位数。

    2.11 LTRIM(char [, set]) :去掉字符串 char 左侧包含在 set 中的任何字符,直到第一个不在 set 中出现的字符为止。

      先看几个实例:

      select ltrim('109224323','109') from dual;  224323

      再来看一个:

      select ltrim('10900094323','109') from dual;  4323

      按道理说应该是00094323的结果嘛~~  再来看两个对比的:

      select ltrim('10900111000991110224323','109') from dual;  224323

      select ltrim('109200111000991110224323','109') from dual;  200111000991110224323

      是不是有这样的疑问:为什么第二个查询语句多了一个2就没被截了呢?

      再来看一个:

       select ltrim('902100111000991110224323','109') from dual;  2100111000991110224323

      按道理说是截109的值,为什么90也被截了?

      总结:LTRIM(x,y) 函数是按照y中的字符一个一个截掉x中的字符,并且是从左边开始执行的,只要遇到y中有的字符, x中的字符都会被截掉, 直到在x的字符中遇到y中没有的字符为止函数命令才结束.

    2.12 RTRIM(char [, set])

      与LTRIM类似,把char 中最右边的字符去掉,使其最后一个字符不在set中,如果没有set,那么char就不会改变。

    2.13 REPLACE(char1, char2, char3)char1,char2,char3都是字符串,函数用char3代替出现在char1中的cchar2后返回。

      select REPLACE('uptown','up','down') from dualREPLACEdowntown

    2.14 SUBSTR(char, m [,n]) :用于获取字符串的子串,m为子串的起始位置,n为子串的长度。

      c1为一字符串,i,j为整数,从c1的第i位开始返回长度为j的子字符串,如果j为空,则直到串的尾部。

      select SUBSTR('Message',1,4) from dual

      Mess

    2.15 SUBSTRB(c1, i [,j])

      与SUBSTR大致相同,只是I,J是以字节计算。

    2.16 SOUNDEX()

      SOUNDEX函数返回字符串参数的语音表示形式,相对于比较一些读音相同,但是拼写不同的单词是非常有用的。

      SOUNDEX函数的语法:

      SOUNDEX(string)

      计算语音的算法:

      1.保留字符串首字母,但删除a、e、h、i、o、w、y

      2.将下表中的数字赋给相对应的字母

      (1) 1:b、f、p、v

      (2) 2:c、g、k、q、s、x、z

      (3) 3:d、t

      (4) 4:l

      (5) 5:m、n

      (6) 6:r

      3. 如果字符串中存在拥有相同数字的2个以上(包含2个)的字母在一起(例如b和f),或者只有h或w,则删除其他的,只保留1个

      4.只返回前4个字节,不够用0填充

      示例:

      soundex('two'),soundex('too'),soundex('to'),他们的结果都是T000

      soundex('cap'),soundex('cup'),他们的结果都是C100

      soundex('house'),soundex('horse'),他们的结果都分别是H200,H620

    select SOUNDEX('dawes') Dawes, SOUNDEX('daws') Daws, SOUNDEX('dawson') from dual

    Dawes Daws Dawson

    D200 D200 D250

    2.17 TRANSLATE(string,from_str,to_str)
      执行时,translate依次检查string中的每个字符,然后查找这个字符是否在from_str中存在,如果不存在,那么这个string中的字符被保留,也就是被返回;如果存在,那么,translate会记下这个字符在from_str中的位置,然后用to_str的同样位置的字符代替string中的这个字符。
      from_str可以比to_str长,也就是from_str的字符数目可以比to_str多,在from_str中多出来的字符称为"额外字符",也就是from_str中的位置在to_str中找不到的,比如
      from_str 'abc123'
      to_str 'abc'
      这里from_str中的1的位置是4,但是to_str的总长度是3,没有4,所以在from_STR中的123都是额外字符,如果from_str中的额外字符在string中出现,那么string中这些字符将在返回时被删除。

    举例如下
      select translate('ab12','ab2','00') from dual;
      001
      这里a和b都被替换成了0,因为a在from_str中的位置是1,那么被to_str中的位置1的字符替换,b也是一样的处理,被to_str中的位置2的字符替换,依然是0。string中的1在from_str没有找到,所以被保留下来了,string中的2在from_str中找到了,但是是from_str的额外字符,因为2在from_str中的位置是3,而to_str中是没有3这个位置的,所以string中的2虽然在from_str中找到了,且处于3的位置,但是TO_STR的长度是2,没有3这个位置,所以2在返回时被删除,得到的是001。

      另外to_str不能是NULL或者'',否则会返回空值,translate也不能用于CLOB(超过4000的长字符串类型)。

      可以如下理解:
      [1] 如果string中的字符如果在from_string中没有,那么返回时被保留;
      [2] 如果string中的字符是from_string中的"额外字符",那么返回时被删除;
      [3] 如果string中的字符在from_string中找到,且在to_string中有相应位置的字符,返回时用to_string中的字符替换string中的字符。

    2.18 TRIM([leading | trailing | both] char FROM string) :从字符串string的头、尾或两端去掉字符char

      select TRIM(' space padded ') trim from dual;

      space padded

    2.19 UPPER(char) :返回char的大写,常出现where子串中

      select name from dual where UPPER(name) LIKE 'KI%'NAMEKING

      select trunc(124.1666,-2) trunc1,trunc(124.16666,2) from dual;

      TRUNC1 TRUNC(124.16666,2)

      100   124.16

      返回截尾到n2位小数的n1的值,n2缺省设置为0,当n2为缺省设置时会将n1截尾为整数,如果n2为负值,就截尾在小数点左边相应的位上。

    4、日期函数

      日期函数是指对日期进行处理的函数,函数输入为 DATE 或 TIMESTAMP 类型的数据,输出为 DATE 类型的数据(除 MONTH_BETWEEN 返回整数)。

      Oracle数据库中日期的默认格式为 DD-MON-YY。可以通过设置 NLS_DATE_FORMAT 参数设置当前会话的日期格式,通过 NLS_LANGUAGE 参数设置表示日期的字符集。

    ALTER SESSION SET NLS_DATE_FORMAT='YYYY-MM-DD HH24:MI:SS';
    ALTER SESSION SET NLS_LANGUAGE='AMERIXAN';

    4.1 ADD_MONTHS(d, n) :返回日期d加上n个月后的结果。i可以使任意整数。如果n是一个小数,那么数据库将隐式的他转换成整数,将会截去小数点后面的部分。

    CURRENT_DATE:返回当前会话时区所对应的日期;

    CURRENT_TIMESTAMO[(p)]:返回当前会话时区所对应的日期时间,p表示精度,默认值为6;

    DBTIMEZONE:返回数据库所在的时区;

    EXTRACT(YEAR | MONTH | DAY FROM d):从日期d中获取需要的数据(年、月、日)

    4.2 LAST_DAY(d) :返回日期d所在的月份的最后一天的日期

    LOCALTIMESTAMP[(p)]:返回当前会话时区所对应的日期时间,p表示精度,默认值为6;

    4.3 MONTHS_BETWEEN(d1, d2) :返回d1,d2两个日期相差的月数

      返回d1和d2之间月的数目,如果d1和d2的日的日期都相同,或者都使该月的最后一天,那么将返回一个整数,否则会返回的结果将包含一个分数。

    4.4 NEW_TIME(d,  tz1, tz2): d是一个日期数据类型,当时区tz1中的日期和时间是d时,返回时区tz2中的日期和时间。tz1和tz2时字符串。

    4.5 NEXT_DAY(d, string) 返回日期d后由string指定的第一个工作日所对应的日期,string使用当前会话中给出的语言指定了一周中的某一天,返回的时间分量与d的时间分量相同。

    select NEXT_DAY('01-Jan-2000','Monday') "1st Monday",NEXT_DAY('01-Nov-2004','Tuesday')+7 "2nd Tuesday") from dual;

    1st Monday 2nd Tuesday

    03-Jan-2000 09-Nov-2004

    4.6 ROUND(d ,[ fmt ]) :返回日期的四舍五入结果,将日期d按照fmt指定的格式舍入,fmt为字符串。

    4.7 SYADATE()返回当前系统的日期时间。

      可用 TO_CHAR(x [, fmt]])  或 TO_DATE(char [,fmt]格式化日期串。

    4.8 TRUNC(d , [ fmt ]) :返回截断日期时间数据.

    5、转换函数

      主要指将一种类型的数据转换为另一种类型的数据。在某些情况下,Oracle会隐含的转换数据类型。

    CAST(expr AS datatype):将表达式expr按指定的类型返回。

    5.1 CHARTORWID(char) :char一个字符串,函数将char转换为RWID数据类型。

      SELECT test_id from test_case where rowid=CHARTORWID('AAAA0SAACAAAALiAAA')

    5.2 CONVERT(c1, dset[, sset]) :c1尾字符串,dset、sset是两个字符集,函数将字符串c1由sset字符集转换为dset字符集,sset的缺省设置为数据库的字符集。

    5.3 HEXTORAW(char) :char为16进制的字符串,函数将16进制的x转换为RAW数据类型。

    5.4 RAWTOHEX(raw) :raw是RAW数据类型字符串,函数将RAW数据类转换为16进制的数据类型。

    5.5 ROWIDTOCHAR(rowid) :函数将ROWID数据类型转换为CHAR数据类型。

    5.6 TO_CHAR(x [, fmt]]) :

      x是一个date或number数据类型,函数将x转换成fmt指定格式的char数据类型,如果x为日期nlsparm=NLS_DATE_LANGUAGE 控制返回的月份和日份所使用的语言。如果x为数字nlsparm=NLS_NUMERIC_CHARACTERS 用来指定小数位和千分位的分隔符,以及货币符号。

      NLS_NUMERIC_CHARACTERS ="dg", NLS_CURRENCY="string"

    5.7 TO_DATE(char [,fmt]) :c表示字符串,fmt表示一种特殊格式的字符串。返回按照fmt格式显示的c,nlsparm表示使用的语言。函数将字符串c转换成date数据类型。

    TO_CLOB(cahr):将字符串转化为 CLOB 类型数据。

    5.8 TO_MULTI_BYTE() :c表示一个字符串,函数将c的担子截字符转换成多字节字符。

    5.9 TO_NUMBER(char [, fmt]) :c表示字符串,fmt表示一个特殊格式的字符串,函数返回值按照fmt指定的格式显示。nlsparm表示语言,函数将返回c代表的数字。

    5.10 TO_SINGLE_BYTE() :将字符串c中得多字节字符转化成等价的单字节字符。该函数仅当数据库字符集同时包含单字节和多字节字符时才使用

     

    6、其它函数

      Oracle还提供了一些其他的函数。

    6.1 BFILENAME( dir, filename): dir是一个Directory类型的对象,file为一文件名。函数返回一个空的BFILE位置值指示符,函数用于初始化BFILE变量或者是BFILE列。

    6.2 DECODE(base_expr, expr1, value1, expr2[,value2,...default]) :

      base_expr是一个表达式,exprn是一个匹配表达式,如果base_expr=exprn,则返回 valuen的值。

    6.3 DUMP(,[,[,[,]]]) x是一个表达式或字符,fmt表示8进制、10进制、16进制、或则单字符。函数返回包含了有关x的内部表示信息的VARCHAR2类型的值。如果指定了n1,n2那么从n1开始的长度为n2的字节将被返回。

    6.4 EMPTY_BLOB() 该函数没有参数,函数返回一个空的BLOB位置指示符。函数用于初始化一个BLOB变量或BLOB列。

    6.5 EMPTY_CLOB() 该函数没有参数,函数返回一个空的CLOB位置指示符。函数用于初始化一个CLOB变量或CLOB列。

    6.6 GREATEST(expr1,expr2, ...) :返回几个表达式中的最大值,每个表达式都被隐含的转换第一个表达式的数据类型,如果第一个表达式是字符串数据类型中的任何一个,那么返回的结果是varchar2数据类型,同时使用的比较是非填充空格类型的比较。

    6.7 LEAST(expr1,expr2, ...) :返回几个表达式中的最小值,每个表达式都被隐含的转换第一个表达式的数据类型,如果第一个表达式是字符串数据类型中的任何一个,将返回的结果是varchar2数据类型,同时使用的比较是非填充空格类型的比较。

    NULLIF(expr1, expr2):如果expr1 与 expr2相等,则返回NULL,否则返回expr1.

    NVL(expr1, expr2):如果expr1为null时,返回expr22,否则返回expr1。

      在如何理解NULL上开始是很困难的,就算是一个很有经验的人依然对此感到困惑。NULL值表示一个未知数据或者一个空值,算术操作符的任何一个操作数为NULL值,结果均为提个NULL值,这个规则也适合很多函数,只有CONCAT,DECODE,DUMP,NVL,REPLACE在调用了NULL参数时能够返回非NULL值。在这些中NVL函数是最重要的,因为他能直接处理NULL值。

    下面我们看看emp数据表它包含了薪水、奖金两项,需要计算总的补偿

    column name emp_id salary bonuskey type pk nulls/unique nn,u nnfk table datatype number number numberlength 11.2 11.2

    不是简单的将薪水和奖金加起来就可以了,如果某一行是null值那么结果就将是null,比如下面的例子:

    update empset salary=(salary+bonus)*1.1

    这个语句中,雇员的工资和奖金都将更新为一个新的值,但是如果没有奖金,即 salary + null,那么就会得出错误的结论,这个时候就要使用nvl函数来排除null值的影响。

    所以正确的语句是:

    update empset salary=(salary+nvl(bonus,0)*1.1

    NVL2(expr1, expr2, expr3):如果expr1为null时,返回expr3,否则返回expr2。

    6.8 UID():返回唯一标示当前数据库用户的ID。

    6.9 USER(0: 返回当前用户的用户名

    6.10 USERENV()

    基于opt返回包含当前会话信息。opt的可选值为:

    ISDBA    会话中SYSDBA脚色响应,返回TRUE

    SESSIONID  返回审计会话标示符

    ENTRYID   返回可用的审计项标示符

    INSTANCE  在会话连接后,返回实例标示符。该值只用于运行Parallel 服务器并且有 多个实例的情况下使用。

    LANGUAGE  返回语言、地域、数据库设置的字符集。

    LANG    返回语言名称的ISO缩写。

    TERMINAL  为当前会话使用的终端或计算机返回操作系统的标示符。

    6.11 VSIZE() x是一个表达式。返回x内部表示的字节数。

    二、SQL中的组函数

      组函数也叫集合函数,返回基于多个行的单一结果,行的准确数量无法确定,除非查询被执行并且所有的结果都被包含在内。与单行函数不同的是,在解析时所有的行都是已知的。由于这种差别使组函数与单行函数有在要求和行为上有微小的差异.

  • 相关阅读:
    axios
    vue-cli-service 报错
    避免大型、复杂的布局和布局抖动
    vue 父子通信
    == 区别 === ,!= 区别 !==
    全选/取消全选
    vue 注意
    pyparsing:自定义一个属于你的语法解析器(更新中)
    《python解释器源码剖析》第11章--python虚拟机中的控制流
    collections:内建模块,提供额外的集合类
  • 原文地址:https://www.cnblogs.com/xinaixia/p/5801731.html
Copyright © 2011-2022 走看看