Oracle学习(三)——15天Oracle入门

                                                         

                                                Oracle入门(三) 这些常用的函数你有多少不知道?

 

          虽然我不提倡把业务逻辑在sql中处理,但一些简单的业务我认识还是在sql中处理,会让我节省不少功夫与效率,以下就常用的简单函数,有时可以让我们事半功倍,你记住了多少,又用到了多少?

   --数值涵数
  select abs(-100)from dual --返回绝对值
  select sign(100),sign(-100),sign(0)from dual--正数返回1,负数返回-1,0返回0
  select ceil(3.1)from dual --Ceil返回比数值大的最小整数
  select floor(3.1)from dual --floor返回比数值小的最大整数
  select power(2.5,2) from dual --返回power(m,n)m的n次方
  select exp(3)from dual--返回e的3次方
  select mod(35,8)from dual--返回35模8的值
  select round(6388.8413)from dual--四舍五入 默认为小数点
  select round(6388.8413)from dual--四舍五入到小数点后多少位
  select round(6388.8413,2.56)from dual--四舍五入到小数点后多少位其和上面等价
  select round(6388.8413,-2)from dual--四舍五入到小数点前多少位
  select trunc(2343.856)from dual--直接截取数值不四舍五入结果为2343(默认为小数点后0位)
  select trunc(2343.856,2)from dual--直接截取小数点后两位不四舍五入结果为2343.85
  select trunc(2343.856,-2)from dual--直接截取小数点前两位不四舍五入结果为2300
  select sqrt(16)from dual--返回平方根+4
  --三角涵数
  select sin(1.57079) from dual;--SIN(x)返回一个数字的正弦值
  select sin(20),sinh(20) from dual;--SIGH(x)返回双曲正弦的值
  select cos(-3.1415927) from dual;--COS(x)返回一个给定数字的余弦
  select cosh(20) from dual;--COSH(x)返回一个数字反余弦值
  select tan(20),tan(10) from dual;--TAN返回数字的正切值
  select tanh(20),tan(20) from dual;--TANH返回数字n的双曲正切值
  select asin(0.5) from dual;--ASIN(x)给出反正弦的值
  select acos(-1) from dual;-- ACOS(x)给出反余弦的值
  select atan(1) from dual;--ATAN(x)返回一个数字的反正切值
  --字符涵数
  select ascii('a')from dual--返回ascii码
  select chr(97)from dual--由ASCII码返回字符
  select concat('asdasd','ffff')from dual;--连接两个字符串
  select initcap('asd asd')from dual--将首安母大写以空格为分界返回Asd Asd
  select lower ('AAA')from dual --全部返回小写
  select upper('aaa')from dual --全部返回大写
  select length('asdas呵呵')from dual --返回字符的长度,汉字按一个字节计算返回7;
  select lpad('呵呵',10,'*')from dual--lpad(s1,n,s2)在s1左边填写s2直到长度为民时结束
                                     --返回******呵呵此时汉字长度按2个字节计算
  select rpad('呵呵',10,'*')from dual --在右边填写                                  
  select instr('呵呵哈哈呵哈','呵哈',1,2)from dual--instr(s1,s2,m,n)从字符(串)s1的第m个位置开始查找
                                      --处n次出现字符(串)s2的位置返回5;
  select ltrim('abaacd','ac')from dual-- ltrim(s1,s2)从s1左边开始查找第一个不是s2集合中的元素时将s1中左
                                      -- 边含s2的元素去掉返回baacd
  select rtrim('abaacd','ad')from dual--从右边删除返回abaac
  select trim('x'from'xxsda xxdxx asdxx')from dual--从两头删除返回sdaxxdxxasd trim(s1,s2)中s1只能为单字符
  select replace('Hao are you','Hao','Who')from dual--替代replace(s1,s2,s3)其中s3可以省略为空
  select translate('Hao are you','Hao','Who')from dual--功能和replace一样只是其参数不可以省
  select substr('hao are you',3,9)from dual;--从字符串的第三位开始取到第9位返回"o are you"
      
       TRUNC(45.936,2) FROM dual                                     --空格不算,汉字按两个字节计算
 --- 日期涵数
  select sysdate from dual;    --得到系统当前时间
  select add_months(sysdate,3)from dual --当前时间上加3
  select last_day(to_date('2009-08-25','YYYY-MM-DD'))from dual  --当前月的最后一天返回2009-8-31
  select months_between(sysdate,to_date('2009-08-25','YYYY-MM-DD')) from dual
                                            --  months_between(d1,d2) d1>d2?正:负
  select sysdate 当时日期,
  round(sysdate) 最近0点日期,
  round(sysdate,'day') 最近星期日,
  round(sysdate,'month') 最近月初,
  round(sysdate,'q') 最近季初日期,
  round(sysdate,'year') 最近年初日期 from dual;
  select sysdate 当时日期,
  trunc(sysdate) 今天日期,
  trunc(sysdate,'day') 本周星期日,
  trunc(sysdate,'month') 本月初, trunc(sysdate,'q')
  本季初日期, trunc(sysdate,'year') 本年初日期 from dual
  select sysdate 当时日期,
  next_day(sysdate,'星期一') 接下来星期一,
  next_day(sysdate,'星期三') 接下来的星期三,
  next_day(sysdate,'星期四') 接下来星期四,
  next_day(sysdate,'星期五') 接下来星期五,
  next_day(sysdate,'星期六') 接下来星期六,
  next_day(sysdate,'星期日') 接下来星期日 from dual
  
  select sysdate 当前日期,
  next_day(sysdate,'星期一')下个星期一,
  next_day(sysdate,'星期二')下个星期二,
  next_day(sysdate,'星期四')下个星期四,
  next_day(sysdate,'星期日')下个星期天
   from dual
 
  selectextract(hour from timestamp '2001-2-16 2:38:40 ') 小时,
       extract(minute from timestamp '2001-2-16 2:38:40 ') 分钟,
       extract(second from timestamp '2001-2-16 2:38:40 ') 秒,
       extract(day from timestamp '2001-2-16 2:38:40 ') 日,
       extract(MONTH from timestamp '2001-2-16 2:38:40 ') 月,
       extract(YEAR from timestamp '2001-2-16 2:38:40 ') 年 from dual;

  --通用涵数其中expr1,exper2,exper3的类型应该是相同的,若exper2与exper3的类型不相同则exper3会自动转化
    select sal,comm ,sal+nvl(comm,0) from emp --nvl(expr1, expr2),若expr1为空则返回expr1否则返回expr2
    select sal,comm , nvl2(comm,ename,sal) from emp--nvl(expr1,expr2,expr3),expr1为空返回expr3若
                                                   --expr1不为空返回expr2
    select nullif(2,2)from dual--mullif(expr1, expr2)expr1, expr2相等返回null 不相等返回expr1.
  --分组与分组涵数  having必须紧跟group by语句 对分组函数进行过滤只能用having子句不能使用where过滤

你可能感兴趣的:(oracle,sql)