Oracle functions 大全
ABS
返回指定值的绝对值
SQL> select abs(100),abs(-100) from dual; ABS(100) ABS(-100) --------- --------- 100 100
ACOS
给出反余弦的值
SQL> select acos(-1) from dual; ACOS(-1) --------- 3.1415927
ADD_MONTHS
ADD_MONTHS(,<i>),增加或减去月份,返回日期d加上i个月后的结果。i可以使任意整数。如果i是一个小数,那么数据库将隐式的他转换成整数,将会截去小数点后面的部分。
SQL> select to_char(add_months(to_date('199912','yyyymm'),2),'yyyymm') from dual; TO_CHA ------ 200002
SQL> select to_char(add_months(to_date('199912','yyyymm'),-2),'yyyymm') from dual;
TO_CHA ------ 199910
Ascii
返回与指定的字符对应的十进制数;
SQL> select ascii('A') A,ascii('a') a,ascii('0') zero,ascii(' ') space from dual;
A A ZERO SPACE --------- --------- --------- --------- 65 97 48 32
逆函数是CHR()
ASIN
给出反正弦的值
SQL> select asin(0.5) from dual; ASIN(0.5) --------- .52359878
ATAN
返回一个数字的反正切值 SQL> select atan(1) from dual; ATAN(1) --------- .78539816
ATAN2
Atan2(n,m):该函数用于返回数字n除以数字m的反正切值。输入值除了m不能为0外,可以是任意数字(m不能为0),输出值的单位为弧度。
AVG
返回数值的平均值。缺省设置为ALL
BFILENAME(dir,file)
指定一个外部二进制文件,dir是一个directory类型的对象,file为一文件名。函数返回一个
空的BFILE位置值指示符,函数用于初始化BFILE变量或者是BFILE列。 SQL>insert into file_tb1 values(bfilename('lob_dir1','image1.gif'));
CEIL
返回大于或等于给出数字的最小整数 SQL> select ceil(3.1415927) from dual; CEIL(3.1415927) --------------- 4
CHARTOROWID
函数将c转换为RWID数据类型
SELECT test_id from test_case where rowid=CHARTORWID(''AAAA0SAACAAAALiAAA'')
CHR
给出整数,返回对应的字符;
SQL> select chr(54740) zhao,chr(65) chr65 from dual; ZH C -- - 赵 A
CONCAT
连接两个字符串;
SQL> select concat('010-','88888888')||'转23' 高乾竞电话 from dual 高乾竞电话 ---------------- 010-88888888转23
CONVERT(c,dset,sset)
将源字符串 sset的字符从一个语言字符集转换到另一个目的dset字符集 SQL> select convert('strutz','we8hp','f7dec') \ conver ------ strutz
COS
返回一个给定数字的余弦
SQL> select cos(-3.1415927) from dual; COS(-3.1415927) --------------- -1
COSH
返回n的双曲余玄值,n 为数字。
select COSH(<1.4>) FROM dualCOSH(1.4)2.15089847
SQL> select cosh(20) from dual; COSH(20) --------- 242582598
COUNT
COUNT({*|DISTINCT|ALL} )
返回查询中行的数目,缺省设置是ALL,*表示返回所有的行 select area_id,min(area_description),count(area_id) from code_city group by area_id
order by count(*) desc
SQL> select count(null) from emp; COUNT(NULL) -----------
0
SQL> select count('') from emp; COUNT('') ---------- 0
SQL> select count('1') from emp; COUNT('1') ----------
7
如果参数填上某个列,count会统计select返回结果集中这些列不为空的这些行。 Select count(*) ---slow
Count(1),--fast Count(rowid)—fast From emp;
CURRENT_DATE
该函数用于返回当前会话时区的日期时间。
CURRENT_TIMESTAMP
该函数用于返回当前会话时区的日期时间。
DBTIMEZONE
该函数用于返回数据库所在的时区。
DECODE
x是一个表达式,m1是一个匹配表达式,x与m1比较,如果m1等于x,那么返回r1,否则,x与m2比较,依次类推m3,m4,m5....直到有返回结果。
DEREF
DUMP(s,fmt,start,length)
DUMP函数以fmt指定的内部数字格式返回一个VARCHAR2类型的值 SQL> col global_name for a30 SQL> col dump_string for a50