or_总结_易_优_oracle函数

注意N表示数字型,C表示字符型,D表示日期型,[]表示内中参数可被忽略,fmt表示格   式。

  单值函数在查询中返回单个值,可被应用到select,where子句,start with以及connect by    子句和having子句。

汇总函数

1 COUNT(*):  (标准) --count*|distinct|all]x)(聚组)

该函数将返回满足WHERE 条件子句中记录的个数

例如:SELECT COUNT(SQLT.TEAM_NAME) FROM SQL21_TEAMSTATS SQLT

2 SUM(*);(标准) --sum([distinct|all]x)(聚组)

SUM 就如同它的本意一样它返回某一列的所有数值的和

例如:SELECT SUM(SQLT.TEAM_AB) FROM SQL21_TEAMSTATS SQLT;

3 AVG(*)(标准)   --avg([distinct|all]x](聚组)

AVG 可以返回某一列的平均值

例如:SELECT AVG(SQLT.TEAM_HITS) FROM SQL21_TEAMSTATS SQLT;

4 MAX(*)(标准) --max([distinct|all]x)(聚组)

如果你想知道某一列中的最大值请使用MAX

例如:SELECT MAX(SQLT.TEAM_HITS) FROM SQL21_TEAMSTATS SQLT;

注意:MAX 返回了最高的字符串最大的是所以说MAX 既可以处理数值也可以处理字   

5 MIN(*)(标准) --min([distinct|all]x)(聚组)

MIN MAX 类似它返回一列中的最小数值.

例如:SELECT MIN(SQLT.TEAM_HITS) FROM SQL21_TEAMSTATS SQLT;

注意:同MAX();

6 VARIANCE(*)(标准) --variance([distinct|all]x)(聚组)

VARIANCE(方差)不是标准中所定义的,但它却是统计领域中的一个至关重要的数值

例如:SELECT VARIANCE(SQLT.TEAM_HITS) FROM SQL21_TEAMSTATS SQLT;

7 STDDEV()(标准) --stddev([distinct|all]x)(聚组)

这是最后一个统计函数STDDEV 返回某一列数值的标准差

例如:SELECT STDDEV(SQLT.TEAM_HITS) FROM SQL21_TEAMSTATS SQLT;

注意:这些统计函数也可以在一个语句中同时使用

8

日期/时间函数

1 ADD_MONTHS(*, N)(标准)

返回指定日期月份+n之后的值,n可以为任何整数。

例如:SELECT ADD_MONTHS(SQLP.PRO_STARTDATE, 4FROM SQL21_PROJECT    SQLP;

  还有:SELECT * FROM SQL21_PROJECT SQLP WHERE 

      ADD_MONTHS(SQLP.PRO_STARTDATE, 1) > SQLP.PRO_ENDDATE;

注意:一部分的函数都可能工作在不只一个地方但是如果没有TO_CHAR TO_DATE   函数的帮助ADD_MONTH就无法在字符或数字类型中工作

2 LAST_DAY(*)(标准)

返回指定时间所在月的最后一天 

例如:SELECT LAST_DAY(SYSDATEFROM DUAL;

3 MONTHS_BETWEE(D1, D2)(标准)

返回d1与d2间的月份差,视d1,d2的值大小,结果可正可负,当然也有可能为0

例如:SELECT MONTHS_BETWEEN(SQLP.PRO_ENDDATE, SQLP.PRO_STARTDATE)    FROM SQL21_PROJECT SQLP;

4 NEW_TIME()(标准)

如果你想把时间调整到你所在的时区你可以使用NEW_TIME 下边给出了所有的时区

简写时区简写时区

AST or ADT 大西洋标准时间 HST or HDT 阿拉斯加_夏威夷时间

BST or BDT 英国夏令时 MST or MDT 美国山区时间

CST or CDT 美国中央时区 NST 新大陆标准时间

EST or EDT 美国东部时区 PST or PDT 太平洋标准时间

GMT 格伦威治标准时间 YST or YDT Yukon 标准时间

例如:SELECT SQLP.PRO_STARTDATE, NEW_TIME(SQLP.PRO_STARTDATE, 

  'NST''CST'FROM SQL21_PROJECT SQLP;

5 NEXT_DAT(*,  N)(标准)

返回指定日期后第一个n的日期,n为一周中的某一天。但是,需要注意的是n如果为字 符的话,它的星期形式需要与当前session默认时区中的星期形式相同。

例如:SELECT SQLP.PRO_STARTDATE, NEXT_DAY(SQLP.PRO_STARTDATE, 5    FROM SQL21_PROJECT SQLP;

6 SYSDATE (标准)

SYSDATE 将返回系统的日期和时间

例如:SELECT SYSDATE FROM SQL21_PROJECT;

7 CURRENT_DATE (oracle存在)

返回当前session所在时区的默认时间 

例如:SELECT CURRENT_DATE FROM DUAL

注意:功能与SYSDATE相同如果同时使用sysdate与current_date获得的时间不一定相   同,某些情况下current_date会比sysdate快一秒。

8 ROUND(*,  [fm])(oracle存在)

后面讲数值型函数的时候介绍ROUND,此处与上功能基本相似,不过此处操作的是日 期。如果不指定fmt参数,则默认返回距离指定日期最近的日期。

例如:SELECT ROUND(SQLP.PRO_STARTDATE, 'MM'FROM SQL21_PROJECT 

  SQLP;

    注意:fm的参数就是那些日期YYYY,MM,DD等 

9 TRUNC(*, [fm])(oracle存在)

后面讲数值型函数的时候介绍TRUNC, 参数同上

例如:SELECT TRUNC(SQLP.PRO_STARTDATE, 'MM'FROM SQL21_PROJECT 

          SQLP;

10 CURRENT_TIMESTAMP([n])(oracle存在) 

返回当前session所在时区的日期和时间。n表示毫秒级的精度,不大于6 

例如:SELECT CURRENT_TIMESTAMP(5FROM DUAL; 

11 LOCALTIMESTAMP([n]) (oracle存在) 

返回当前session所在时区的日期和时间。n表示毫秒级的精度,不大于6 

例如:SELECT LOCALTIMESTAMP(3FROM DUAL; 

12 SYSTIMESTAMP([n]) (oracle存在) 

返回当前数据库所在时区的日期和时间,n表示毫秒级的精度,>0 and <6 

例如:SELECT SYSTIMESTAMP(4FROM DUAL; 

13 DBTIMEZONE (oracle存在) 

返回数据库的当前时区 

例如:SELECT DBTIMEZONE FROM DUAL; 

14 SESSIONTIMEZONE (oracle存在) 

返回当前session所在时区

例如:SELECT SESSIONTIMEZONE FROM DUAL;

15 EXTRACT(key from date)  key=(year,month,day,hour,minute,second)(oracle存在) 

从指定时间提到指定日期列 

例如:SELECT EXTRACT(year from sysdateFROM DUAL;  

16 TO_TIMESTAMP(c1[,fmt]) (oracle存在) 

将指定字符按指定格式转换为timestamp格式

例如:SELECT TO_TIMESTAMP('2007-8-22''YYYY-MM-DD HH:MI:SS'   FROM DUAL; 

17

数学函数

数值型函数输入数字型参数并返回数值型的值。多数该类函数的返回值支持38位小数点,诸如:COS, COSH, EXP, LN, LOG, SIN, SINH, SQRT, TAN, and TANH 支持36位小数点。ACOS, ASIN, ATAN, and ATAN2支持30位小数点。

1 ABS(*)(标准)

ABS 函数返回给定数字的绝对值

例如:SELECT ABS(SQLN.NUM_A) FROM SQL21_NUMBERS SQLN;

2 CELT(N) 和 FLOOR(N)(标准)

CELT(N): 返回大于或等于n的最小的整数值

FLOOR(N):  返回小于等于n的最大整数值 

例如:SELECT FLOOR(-2.2FROM DUAL;

          SELECT CEIL(18.2FROM DUAL; 

3 COS, COSH, SIN, SINH, TAN, TANH... (N) (标准)

COS,SIN,TAN可以返回给定参数的三角函数值, COSH,SIHN,TANH则返回双曲余弦,正弦, 正切,注意:默认的参数认定为弧度制

例如:SELECT SQLN.NUM_A, COS(SQLN.NUM_A*0.01745329251994FROM 

  SQL21_NUMBERS SQLN;

4 ACOS, ASIN, ATAN(N)(oracle存在)

反三角函数ACOS,ASIN  N between -1 and 1; ATAN , n表示弧度,返回值between pi/2 and  -pi/2

例如:SELECT ASIN(0.7) FROM DUAL;

5 EXP(N)(标准)

返回e的n次幂,e = 2.71828183 ... 

例如:SELECT EXP(3FROM DUAL; 

6 LN(N) 和 LOG(N1, N2)(标准)

这是两个对数函数其中LN 返回给定参数的自然对数,n2>0 , LOG返回以n1为底n2的对 数,n1 >0 and not 1 ,n2>0 

例如:SELECT LN(20FROM DUAL;

7 MOD(N1, N2)(标准)

返回n1除n2的余数,如果n2=0则返回n1的值。

例如:SELECT MOD(103FROM DUAL;

8 POWER(N1, N2)(标准)

返回n1的n2次方。n1,n2可以为任意数值,不过如果N1是负数,则N2必须为整数 

例如:SELECT POWER(23.1) FROM DUAL;

9 SING(N)(标准)

如果n<0返回-1,如果n>0返回1,如果n=0返回0.

例如:SELECT SIGN(-20), SIGN(20FROM DUAL;

10 SQRT(N)(标准)

返回n的平方根,n>=0 

例如:SELECT SQRT(20FROM DUAL;

11 BITAND(N1, N2)(oracle存在)

位与运算,这个太有意思了,虽然没想到可能用到哪里,详细说明一下: 

假设3,9做位与运算,3的二进制形式为:0011,9的二进制形式为:1001,则结果是0001, 转换成10进制数为1。

例如:SELECT BITAND(107FROM DUAL;

12 BIN_TO_NUM(N1, N2, N3, N4........)(oracle存在)

二进制转向十进制 

例如:SELECT BIN_TO_NUM(1,0,1,1), BIN_TO_NUM(1FROM DUAL;

13 ROUND(n1, [n2])(oracle存在)

返回四舍五入小数点右边n2位后n1的值,n2缺省值为0,如果n2为负数就舍入到小数点左边相应的位上(虽然oracle documents上提到n2的值必须为整数,事实上执行时此处的判断并不严谨,即使n2为非整数,它也会自动将n2取整后做处理,但是我文档中其它提到必须为整的地方需要特别注意,如果不为整执行时会报错的)。 

例如:SELECT ROUND(23.56),ROUND(23.56,1),ROUND(23.56,-1FROM  DUAL; 

14 TRUNC(n1, [n2])(oracle存在)

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

例如:SELECT TRUNC(23.56),TRUNC(23.56,1),TRUNC(23.56,-1FROM     DUAL;

15

字符函数

该类函数返回与输入类型相同的类型。 

1) 返回的CHAR类型值长度不超过2000字节; 

2) 返回的VCHAR2类型值长度不超过4000字节; 

如果上述应返回的字符长度超出,oracle并不会报错而是直接截断至最大可支持长度返回。 

3) 返回的CLOB类型值长度不超过4G; 

对于CLOB类型的函数,如果返回值长度超出,oracle不会返回任何错误而是直接抛出错误。 

1 CHAR(N[USING NCHAR_CS])(标准)

返回指定数值在当前字符集中对应的字符,返回的字符取决于数据库所依赖的字符集

例如示例的数据库采用了ASCLL, 字符集示例数据库的代码列的内容为数字.

例如:SELECT SQLC.CHAR_CODE, CHR(SQLC.CHAR_CODE) FROM

SQL21_CHARACTERS SQLC;

2 CONCAT(C1, C2)(标准)

连接字符串,等同于|| 

例如:SELECT CONCAT(SQLC.CHAR_FIRSTNAME, SQLC.CHAR_LASTNAME) FROM 

  SQL21_CHARACTERS SQLC;

3 INITCAP(C)(标准)

该函数将参数的第一个字母变为大写此外其它的字母则转换成小写

例如:SELECT INITCAP(SQLC.CHAR_FIRSTNAME) FROM SQL21_CHARACTERS 

  SQLC;

4 LOWER(C) 和UPPER(C)(标准)

LOWER 将参数转换为全部小写字母而UPPER 则把参数全部转换成大写字

,支持CHAR,VARCHAR2,NCHAR,NVARCHAR2,CLOB,NCLOB类型 

例如:SELECT LOWER(SQLC.CHAR_FIRSTNAME) FROM SQL21_CHARACTERS 

  SQLC; 

5 LPAD(C1, N, [C2])和RPAD(C1, N , [C2])(标准)

这两个函数最少需要两个参数,最多需要三个参数:每一个参数是需要处理的字符串,

第二个参数是需要将字符串扩充的宽度,第三个参数表示加宽部分用什么字符来做填补,

第三个参数的默认值为空格但也可以是单个的字符或字符串下面的句子中向字段中 加入了五个字符该字段的定义宽度为5

返回指定长度=n的字符串,需要注意的有几点:

a、如果n<c1.length则从右到左截取指定长度返回; 

b、如果n>c1.length and c2 is null,以空格从左向右补充字符长度至n并返回; 

c、如果n>c1.length and c2 is not null,以指定字符c2从左向右补充c1长度至n并返回;

例如:SELECT RPAD(SQLC.CHAR_LASTNAME, 30'*#')  FROM 

  SQL21_CHARACTERS SQLC;

6 LTRIM(C1, [C2])和RTRIM(C1, [C2])(标准)

LTRIM RTRIM至少需要一个参数,最多允许两个参数第一个参数与LPAD RPAD类似是一个字符串第二个参数也是一个字符或字符串默认则是空格如果第二个参数不是空格的话那么该函数将会像剪除空格那样剪除所指定的字符

例如:SELECT LPAD(SQLC.CHAR_LASTNAME, 20'*#'), 

LTRIM(LPAD(SQLC.CHAR_LASTNAME, 20'*#'), '*#')

FROM SQL21_CHARACTERS SQLC;

注意:剪除就是从左或右开始判断起,如果第一个字母在C2中出现了的话就剪除,第一   个剪除之后就剪第二个,如果没有的话第二个就不能剪除了

7 REPLACE(c1, c2, [c3])(标准)

将c1字符串中的c2替换为c3,如果c3为空,则从c1中删除所有c2。

例如:SELECT SQLC.CHAR_LASTNAME, REPLACE(SQLC.CHAR_LASTNAME, 'ST'

          REPLACEMENT FROM SQL21_CHARACTERS SQLC;

8 SUBSTR(C1, N1, [N2])(标准)

截取指定长度的字符串。稍不注意就可能充满了陷阱的函数。 

n1=开始长度; 

n2=截取的字符串长度,如果为空,默认截取到字符串结尾; 

1) 如果n1=0 then n1=1 

2) 如果n1>0,则oracle从左向右确认起始位置截取 

例如:SELECT SUBSTR('What is this',5,3FROM DUAL; 

3) 如果n1<0,则oracle从右向左数确认起始位置 

例如:SELECT SUBSTR('What is this',-5,3FROM DUAL; 

4) 如果n1>c1.length则返回空 

9 TRANSLATE(C1, C2, C3)(标准)

就功能而言,此函数与replace有些相似。但需要注意的一点是translate是绝对匹配替换,这点与replace函数具有非常大区别。什么是绝对匹配替换呢? 简单的说,是将字符串c1中按一定的格式c2替换为c3。

Replace函数理解比较简单,它是将字符串中指定字符替换成其它字符,它的字符必须是连续的。而translate中,则是指定字符串c1中出现的c2,将c2中各个字符替换成c3中位置顺序与其相同的c3中的字符。明白了?Replace是替换,而translate则像是过滤。 

例如:SELECT TRANSLATE('What is this','ait','-*'FROM DUAL; 

就是这样,所有的a用-过滤,i用*过滤,t用空过滤

10 INSTR(C1, C2 [N1], [N2])(标准)

返回c2在c1中位置 

1) c1:原字符串 

2) c2:要寻找的字符串 

3) n1:查询起始位置,正值表示从左到右,负值表示从右到左 (大小表示位置,比如3表示   左面第3处开始,-3表示右面第3处开始)。黑黑,如果为0的话,则返回的也是0 

4) n2:第几个匹配项。大于0 

例如:SELECT INSTR('ABCDE''D', -1FROM DUAL;

注意:本类函数支持所有的数据类型 

11 LENGTH(C)(标准)

LENGTH将返回指定字符串的长度

例如:SELECT LENGTH('A123中'FROM DUAL; 

注意:本类函数支持所有的数据类型

12 TRIM([[LEADING||TRAILING||BOTH] c2 FROM] c1))(oracle存在)

该形容方式搞晕头了吧,这个地方还是看图更明了一些。 看起来很复杂,理解起来很简单: 

1、如果没有指定任何参数则oracle去除c1头尾空格 

例如:SELECT TRIM(' WhaT is tHis 'FROM DUAL; 

2、如果指定了c2参数,则oracle去掉c1头尾c2(这个建议细致测试,有多种不同情形的哟) 

例如:SELECT TRIM('W' FROM 'WhaT is tHis w W'FROM DUAL; 

3、如果指定了leading参数则会去掉c1头部c2 

例如:SELECT TRIM(leading 'W' FROM 'WhaT is tHis w W'FROM 

  DUAL; 

4、如果指定了trailing参数则会去掉c1尾部c2 

例如:SELECT TRIM(trailing 'W' FROM 'WhaT is tHis w W'FROM 

  DUAL; 

5、如果指定了both参数则会去掉c1头尾c2(跟不指定有区别吗?没区别!) 

例如:SELECT TRIM(both 'W' FROM 'WhaT is tHis w W'FROM DUAL; 

注意:c2长度=1 

13 SUNDEX(c)(oracle存在)

神奇的函数啊,该函数返回字符串参数的语音表示形式,对于比较一些读音相同,但是拼写不同的单词非常有用。计算语音的算法如下: 

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

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

1:b、f、p、v 

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

3:d、t 

4:l 

5:m、n 

6:R 

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

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

例如:SELECT SOUNDEX('dog'),soundex('boy'FROM DUAL; 

14 NLS_INITCAP(c) (oracle存在)

返回指定字符串,并将字符串中第一个字母变大写,其它字母变小写 

例如:SELECT NLS_INITCAP('中华miNZHu'FROM DUAL; 

它还具有一个参数:Nlsparam用来指定排序规则,可以忽略,默认状态该参数为当前session的排序规则。

15 ASCII(c) (oracle存在)

与chr函数的用途刚刚相反,本函数返回指定字符在当前字符集下对应的数值。

例如:SELECT ASCII('_'FROM DUAL; 

16

17

转换函数

转换函数将指定字符从一种类型转换为另一种,通常这类函数遵循如下惯例:函数名称后面跟着待转换类型以及输出类型。 

1 TO_CHAR()(标准)

本函数又可以分三小类,分别是 

a) 转换字符->字符TO_CHAR(c):将nchar,nvarchar2,clob,nclob类型转换为char类型; 

例如:SELECT TO_CHAR('AABBCC'FROM DUAL; 

b) 转换时间->字符TO_CHAR(d[,fmt]):将指定的时间(data,timestamp,timestamp with time  zone)按照指定格式转换为varchar2类型; 

例如:SELECT TO_CHAR(sysdate,'yyyy-mm-dd hh24:mi:ss'FROM DUAL; 

c) 转换数值->字符TO_CHAR(n[,fmt]):将指定数值n按照指定格式fmt转换为varchar2 类型并返回; 

例如:SELECT TO_CHAR(-100'L99G999D99MI'FROM DUAL; 

2 TO_NUMBER(C [,FM [,NLS]])(标准)

将char,nchar,varchar2,nvarchar2型字串按照fmt中指定格式转换为数值类型并返回。 

例如:SELECT TO_NUMBER('-100.00', '9G999D99') FROM DUAL; 

3 TO_DATE(C [,FM [,NLS]])(ORACLE存在)

将char,nchar,varchar2,nvarchar2转换为日期类型,如果fmt参数不为空,则按照fmt中指定格式进行转换。注意这里的fmt参数。如果ftm为'J'则表示按照公元制(Julian day)转换,c则必须为大于0并小于5373484的正整数。

例如:SELECT TO_DATE(2454336'J'FROM DUAL; 

SELECT TO_DATE('2007-8-23 23:25:00''yyyy-mm-dd hh24:mi:ss'

              FROM DUAL; 

为什么公元制的话,c的值必须不大于5373484呢?因为Oracle的DATE类型的取值范围是公元前4712年1月1日至公元9999年12月31日。看看下面这个语句: 

     SELECT TO_CHAR(TO_DATE('9999-12-31','yyyy-mm-dd'),'j'

FROM DUAL; 

4 BIN_TO_NUM(n1,n2...n)(ORACLE存在)

将一组位向量转换为等价的十进制形式。

例如:SELECT BIN_TO_NUM(1,1,0FROM DUAL; 

5 CAST(c as newtype) (ORACLE存在)

将指定字串转换为指定类型,基本只对字符类型有效,比如char,number,date,rowid等。此类转换有一个专门的表列明了哪种类型可以转换为哪种类型,此处就不作酹述。

例如:SELECT CAST('1101' AS NUMBER(5)) FROM DUAL; 

6 CHARTOROWID(c) (ORACLE存在)

将字符串转换为rowid类型 

例如:SELECT CHARTOROWID('A003D1ABBEFAABSAA0'FROM DUAL;

7 ROWIDTOCHAR(rowid) (ORACLE存在)

转换rowid值为varchar2类型。返回串长度为18个字节。

例如:SELECT ROWIDTOCHAR(rowidFROM DUAL; 

8 TO_MULTI_BYTE(c)  (ORACLE存在)

将指定字符转换为全角并返回char类型字串

例如:SELECT TO_MULTI_BYTE('ABC abc 中华'FROM DUAL; 

9 TO_SINGLE_BYTE(c)  (ORACLE存在)

将指定字符转换为半角并返回char类型字串

例如:SELECT TO_SINGLE_BYTE('ABC abc中华'FROM DUAL;  

10

其他函数

1 GREATEST(n1, n2, n3, ...)与LEAST(n1, n2, n3, ...)(标准)

GREATEST返回序列中的最大值

例如:SELECT GREATEST(15,5,75,8) "Greatest" FROM DUAL;

LEAST返回序列中的最小值 

例如:SELECT LEAST(15,5,75,8LEAST FROM DUAL;

2 USER(标准)

该函数返回当前使用数据库的用户的名字

例如:SELECT USER FROM DUAL; 

3 DECODE(exp,s1,r1,s2,r2..s,r[,def])(ORACLE存在)

可以把它理解成一个增强型的if else,只不过它并不通过多行语句,而是在一个函数 内实现if else的功能。 

exp做为初始参数。s做为对比值,相同则返回r,如果s有多个,则持续遍历所有s,直到某个条件为真为止,否则返回默认值def(如果指定了的话),如果没有默认值,并且前面的对比也都没有为真,则返回空。 

毫无疑问,decode是个非常重要的函数,在实现行转列等功能时都会用到,需要牢记和熟练使用。 

例如:select decode('a1''a1''true1''a2''true2''default'   from dual;

4 NULLIF(c1,c2) (ORACLE存在)

Nullif也是个很有意思的函数。逻辑等价于:CASE WHEN c1 = c2 THEN NULL ELSE c1 END 

例如:select nullif('a1''b1'from dual;

5 NVL(c1,c2)(ORACLE存在) 

逻辑等价于IF c1 is null THEN c2 ELSE c1 END。c1,c2可以是任何类型。如果两者类型不同,则oracle会自动将c2转换为c1的类型。

例如: select nvl(null'100'from dual;

6 NVL2(c1,c2,c3)(ORACLE存在) 

大家可能都用到nvl,但你用过nvl2吗?如果c1非空则返回c2,如果c1为空则返回c3 

例如:select nvl2('a''b''c') isNull,nvl2(null'b''c'

    isNotNull from dual; 

7 SYS_CONNECT_BY_PATH(col,c)(ORACLE存在)

该函数只能应用于树状查询。返回通过c1连接的从根到节点的路径。该函数必须与connect by 子句共同使用。

例如:  create table tmp3( 

   rootcol varchar2(10), 

    nodecol varchar2(10

   ); 

   insert into tmp3 values ('','a001'); 

   insert into tmp3 values ('','b001'); 

   insert into tmp3 values ('a001','a002'); 

   insert into tmp3 values ('a002','a004'); 

   insert into tmp3 values ('a001','a003'); 

   insert into tmp3 values ('a003','a005'); 

   insert into tmp3 values ('a005','a008'); 

   insert into tmp3 values ('b001','b003'); 

   insert into tmp3 values ('b003','b005'); 

   select lpad(' 'level*10,'='

||'>'|| sys_connect_by_path(nodecol,'/'

   from tmp3 

   start with rootcol = 'a001' 

connect by prior nodecol =rootcol; 

8 SYS_CONTEXT(c1,c2[,n]) (ORACLE存在)

将指定命名空间c1的指定参数c2的值按照指定长度n截取后返回。 

Oracle9i提供内置了一个命名空间USERENV,描述了当前session的各项信息,其拥有下列参数: 

1) CURRENT_SCHEMA:当前模式名; 

2) CURRENT_USER:当前用户; 

3) IP_ADDRESS:当前客户端IP地址; 

4) OS_USER:当前客户端操作系统用户; 

等等数十项,更详细的参数列还请大家直接参考Oracle Online Documents 

例如:SELECT SYS_CONTEXT('USERENV''SESSION_USER'FROM DUAL; 

9 COALESCE(n1,n2,....n)  (ORACLE存在)

返回序列中的第一个非空值 

例如: SELECT COALESCE(null,5,6,null,9FROM DUAL;

10 DUMP(exp[,fmt[,start[,length]]])(ORACLE存在)

dump是个功能非常强悍的函数,对于深入了解oracle存储的人而言相当有用。所以对于我们这些仅仅只是应用的人而言就不知道能将其应用于何处了。此处仅介绍用法,不对其功能做深入分析。

     如上所示,dump拥有不少参数。其本质是以指定格式,返回指定长度的exp的内部 表示形式的varchar2值。fmt含4种格式:8||10||16||17,分别表示8进制,10进制,16进 制和单字符,默认为10进制。start参数表示开始位置,length表示以,分隔的字串数。 

例如: SELECT DUMP('abcdefg',17,2,4FROM DUAL; 

11 EMPTY_BLOB,EMPTY_CLOB(ORACLE存在)

这两个函数都是返回空lob类型,通常被用于insert和update等语句以初始化lob列,或者将其置为空。EMPTY表示LOB已经被初始化,只不过还没有用来存储数据。

12 NLS_CHARSET_NAME(n) (ORACLE存在)

返回指定数值对应的字符集名称。

例如: SELECT NLS_CHARSET_NAME(1FROM DUAL; 

13 NLS_CHARSET_ID(c)(ORACLE存在)

返回指定字符对应的字符集id。

例如: SELECT NLS_CHARSET_ID('US7ASCII'FROM DUAL;

14 NLS_CHARSET_DECL_LEN(n1,n2) (ORACLE存在)

返回一个NCHAR值的声明宽度(以字符为单位).n1是该值以字节为单位的长度,n2是该值的字符集ID

例如: SELECT 

NLS_CHARSET_DECL_LEN(100, nls_charset_id('US7ASCII')) 

FROM DUAL; 

15 SYS_EXTRACT_UTC(timestamp) (ORACLE存在) 

返回标准通用时间即格林威治时间。

例如:  SELECT SYS_EXTRACT_UTC(current_timestamp) FROM DUAL; 

16 SYS_TYPEID(object_type) (ORACLE存在) 

返回对象类型对应的id。 

例如:这个这个,没有建立过自定义对象,咋做示例?

17 UID (ORACLE存在)

返回一个唯一标识当前数据库用户的整数。

例如:select uid from dual; 

18 USERENV(c)  (ORACLE存在)

该函数用来返回当前session的信息,据oracle文档的说明,userenv是为了保持向下兼容的遗留函数。oracle公司推荐你使用sys_context函数调用USERENV命名空间来获取相关信息,所以大家了解下就行了。

例如: SELECT USERENV('LANGUAGE'FROM DUAL

19 VSIZE(c) (ORACLE存在)

返回c的字节数。 

例如:SELECT VSIZE('abc中华'FROM DUAL;

 

20

还没不懂意思的函数

1 userenv(x) (x参数不明)

返回关于当前数据库会话的环境信息

2 rawtohexx

将二进制数据转换成16进制数字的字符串

3

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值