Oracle函数

Oracle函数

1、字符函数
--拼接字符串
select 'asdas'||'dasd' from dual;
select concat('asfsad','sdafsd') from dual;
--将字符串第一个字母变大写,如果是中文不影响运行
select initcap('sadf') from dual;
select initcap('对方告诉对方') from dual;
--找出某个字符床的位置
select instr('sdfgsd','f') from dual;
--查询出该字符串的长度
select length('dfvgdfs     ') from dual;
--trim去掉字符串首位空格 不能去掉字符串中间的空格
select length(trim('  df   vg  dfs     ')) from dual;
--字符串替换
select replace('sadfaasd','a','c') from dual;
--获取字符串子串
select substr('dfesrfer','3','5') from dual;
--将字符串转换成小写
select lower('SEDFdsfASDFgsd') from dual;
--将字符串变为大写
select upper('SGDSFGdsfgDSFG') from dual;
2、数值函数
--绝对值
select abs(-90) from dual; 
--向上取整
select ceil('90.1') from dual;
select ceil('90.9') from dual;
--向下取整
select floor('96.98') from dual;
--取模,求余数
select mod('12.5','3') from dual;
--value的exponent次幂
select power('2','10') from dual;
--按precision 精度4舍5入
select round('32.4') from dual;
select round('32.6') from dual;
--value 的平方根
select sqrt('16') from dual;
--按照precision 截取value
select trunc('1.23456','2') from dual;
3、日期函数
--在日期date上增加count个月
select add_months(sysdate,'2') from dual;
--返回日期date 所在月的最后一天
select last_day(sysdate) from dual;
--给出 Date2 - date1 的月数(可以是小数)
select months_between(sysdate,to_date('20181123','yyyymmss')) from dual;
--给出日期date之后下一天的日期 必须是汉字
select next_day(sysdate,'星期一') from dual;
--ROUND函数判断时间的区间 
select round(sysdate,'yyyy') from dual;
select round(sysdate,'year') from dual;
--MONTH/MM获取这个月的第一天
select trunc(sysdate,'month') from dual;
select trunc(sysdate,'mm') from dual;
select trunc(sysdate,'day') from dual; --少一天
4、转换函数
--转换日期格式到字符串;
select to_char(sysdate) from dual;
--按照指定的格式将字符串转换到日期型
select to_date('2017-01-01','yyyy-mm-dd') from dual;
--将数字字串转换到数字
select to_number('20170101') from dual;
5、其他函数
--空值处理函数 NVL
select * from emp;
select nvl(e.commission_pct,0)as commission_pct,e.* from emp e;
select PRICE,MINNUM,NVL(MAXNUM,9999999) from T_PRICETABLE where OWNERTYPEID=1;
--空值处理函数 NVL2
select PRICE,MINNUM,NVL2(MAXNUM,to_char(MAXNUM) , '不限') from T_PRICETABLE where OWNERTYPEID=1;
--根据条件返回相应值
select name,decode(  ownertypeid,1,'居民',2,'行政事业单位',3,'商业') as 类型   from T_OWNERS;
6、分析函数
--相同的值排名相同,排名跳跃
select rank() over(order by usenum desc),usenum from t_account;
--相同的值排名相同,排名连续
select dense_rank() over(order by usenum desc),usenum from t_account;
--返回连续的排名,无论值是否相等
select row_number() over(order by usenum desc ),usenum from T_ACCOUNT
  • 5
    点赞
  • 47
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值