设为首页 收藏本站
查看: 1167|回复: 0

[经验分享] Oracle系列:(8)单行函数

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2018-9-7 13:06:38 | 显示全部楼层 |阅读模式
  单行函数:只有一个参数输入,只有一个结果输出
  多行函数或分组函数:可有多个参数输入,只有一个结果输出
  测试lower/upper/initcap函数,使用dual哑表
select lower('www.BAIdu.COM') from dual;  
select upper('www.BAIdu.COM') from dual;
  
select initcap('www.BAIdu.COM') from dual;
DSC0000.png

  测试concat/substr函数,从1开始,表示字符,不论中英文
  select concat('hello','你好') from dual;正确
  select concat('hello','你好','世界') from dual;错误
  select 'hello' || '你好' || '世界' from dual;正确
  select concat('hello',concat('你好','世界')) from dual;正确
  select substr('hello你好',5,3) from dual;
  5表示从第几个字符开始算,第一个字符为1,中英文统一处理
  3表示连续取几个字符
DSC0001.png

  测试length/lengthb函数,编码方式为UTF8/GBK,一个中文占3/2个字节长度,一个英文一个字节
select length('hello你好') from dual;  
select lengthb('hello你好') from dual;
DSC0002.png

  测试instr/lpad/rpad函数,从左向右找第一次出现的位置,从1开始
select instr('helloworld','o') from dual;  注意:找不到返回0,大小写敏感
select LPAD('hello',10,'#') from dual;  
select RPAD('hello',10,'#') from dual;
DSC0003.png

  测试trim/replace函数
select trim(' ' from '  he  ll                ') from dual;  
select replace('hello','l','L') from dual;
DSC0004.png

  测试round/trunc/mod函数作用于数值型
select round(3.1415,3) from dual;  
select trunc(3.1415,3) from dual;
  
select mod(10,3) from dual;
DSC0005.png

  当前日期:
select sysdate from dual;
DSC0006.png

  测试round作用于日期型(month)
select round(sysdate,'month') from dual;
DSC0007.png

  测试round作用于日期型(year)
select round(sysdate,'year') from dual;
DSC0008.png

  测试trunc作用于日期型(month)
select trunc(sysdate,'month') from dual;
DSC0009.png

  测试trunc作用于日期型(year)
select trunc(sysdate,'year') from dual;
DSC00010.png

  显示昨天,今天,明天的日期,日期类型 +- 数值 = 日期类型
select sysdate-1 "昨天",sysdate "今天",sysdate+1 "明天" from dual;
DSC00011.png

  以年和月形式显示员工近似工龄,日期-日期=数值,假设:一年以365天计算,一月以30天计算
select ename "姓名",round(sysdate-hiredate,0)/365 "工龄" from emp;
DSC00012.png

  使用months_between函数,精确计算到年底还有多少个月
select months_between('31-12月-16',sysdate) from dual;
DSC00013.png

  使用months_between函数,以精确月形式显示员工工龄
select ename "姓名",months_between(sysdate,hiredate) "精确月工龄" from emp;
DSC00014.png

  测试add_months函数,下个月今天是多少号
select add_months(sysdate,1) from dual;
DSC00015.png

  测试add_months函数,上个月今天是多少号
select add_months(sysdate,-1) from dual;
DSC00016.png

  测试next_day函数,从今天开始算,下一个星期三是多少号【中文平台】
select next_day(sysdate,'星期三') from dual;
DSC00017.png

DSC00018.png

  测试next_day函数,从今天开始算,下下一个星期三是多少号【中文平台】
select next_day(next_day(sysdate,'星期三'),'星期三') from dual;
DSC00019.png

  测试next_day函数,从今天开始算,下一个星期三的下一个星期日是多少号【中文平台】
select next_day(next_day(sysdate,'星期三'),'星期日') from dual;
DSC00020.png

  测试last_day函数,本月最后一天是多少号
select last_day(sysdate) from dual;
DSC00021.png

  测试last_day函数,本月倒数第二天是多少号
select last_day(sysdate)-1 from dual;
DSC00022.png

  测试last_day函数,下一个月最后一天是多少号
select last_day(add_months(sysdate,1)) from dual;
DSC00023.png

  测试last_day函数,上一个月最后一天是多少号
select last_day(add_months(sysdate,-1)) from dual;
DSC00024.png

  注意:
  1)日期-日期=天数
  2)日期+-天数=日期



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-566127-1-1.html 上篇帖子: Oracle系列:(7)order by子句 下篇帖子: oracle sqlldr导入数据
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表