加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

Oracle系列:(8)单行函数

发布时间:2020-12-12 16:01:07 所属栏目:百科 来源:网络整理
导读:单行函数 :只有一个参数输入,只有一个结果输出 多行函数或分组函数 :可有多个参数输入,只有一个结果输出 测试 lower/upper/initcap 函数,使用dual哑表 selectlower('www.BAIdu.COM')fromdual;selectupper('www.BAIdu.COM')fromdual;selectinitcap('www.




单行函数:只有一个参数输入,只有一个结果输出

多行函数或分组函数:可有多个参数输入,只有一个结果输出


测试lower/upper/initcap函数,使用dual哑表

selectlower('www.BAIdu.COM')fromdual;
selectupper('www.BAIdu.COM')fromdual;
selectinitcap('www.BAIdu.COM')fromdual;

wKiom1fPHRLhHJyGAAAeysNLpt8939.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表示连续取几个字符

wKioL1fPHmfBRxAXAAAKN6pXAxQ699.png


测试length/lengthb函数,编码方式为UTF8/GBK,一个中文占3/2个字节长度,一个英文一个字节

selectlength('hello你好')fromdual;
selectlengthb('hello你好')fromdual;

wKioL1fPHxmiubfyAAAUvIAQrUs559.png



测试instr/lpad/rpad函数,从左向右找第一次出现的位置,从1开始

selectinstr('helloworld','o')fromdual;

注意:找不到返回0,大小写敏感

selectLPAD('hello',10,'#')fromdual;
selectRPAD('hello','#')fromdual;

wKiom1fPIEXhSQCAAAAeQopPTkY387.png


测试trim/replace函数

selecttrim(''from'hell')fromdual;
selectreplace('hello','l','L')fromdual;

wKiom1fPIP-S9IXyAAARTLpUnK0556.png


测试round/trunc/mod函数作用于数值型

selectround(3.1415,3)fromdual;
selecttrunc(3.1415,3)fromdual;
selectmod(10,3)fromdual;

wKioL1fPIZahSSGWAAAXhydNrAM118.png



当前日期:

selectsysdatefromdual;

wKioL1fPIiTCOO0VAAAHT1HbNPY405.png



测试round作用于日期型(month)

selectround(sysdate,'month')fromdual;

wKiom1fPInbBlF5KAAAIOlR6SEM294.png


测试round作用于日期型(year)

selectround(sysdate,'year')fromdual;

wKiom1fPIsKRAhy8AAAHEYU1AWw877.png


测试trunc作用于日期型(month)

selecttrunc(sysdate,'month')fromdual;

wKioL1fPIwGja145AAAIMQh_QiU778.png


测试trunc作用于日期型(year)

selecttrunc(sysdate,'year')fromdual;

wKiom1fPI0Xho_6pAAAIMKO1k08355.png


显示昨天,今天,明天的日期,日期类型 +- 数值 = 日期类型

selectsysdate-1"昨天",sysdate"今天",sysdate+1"明天"fromdual;

wKioL1fPI_ziwFdQAAAMMCLr7wA872.png


以年和月形式显示员工近似工龄,日期-日期=数值,假设:一年以365天计算,一月以30天计算

selectename"姓名",round(sysdate-hiredate,0)/365"工龄"fromemp;

wKiom1fPJMnghMXzAAAgF7OgbO8016.png



使用months_between函数,精确计算到年底还有多少个月

selectmonths_between('31-12月-16',sysdate)fromdual;

wKioL1fPJTai5POEAAAKNEQZ2VQ333.png


使用months_between函数,以精确月形式显示员工工龄

selectename"姓名",months_between(sysdate,hiredate)"精确月工龄"fromemp;

wKioL1fPJXiwZHRsAAAinogF5_w664.png


测试add_months函数,下个月今天是多少号

selectadd_months(sysdate,1)fromdual;

wKiom1fPJbfCXwHLAAAIWWW2JjQ613.png


测试add_months函数,上个月今天是多少号

selectadd_months(sysdate,-1)fromdual;

wKioL1fPJgnT0_fuAAAHHOMF-WE744.png


测试next_day函数,从今天开始算,下一个星期三是多少号【中文平台】

selectnext_day(sysdate,'星期三')fromdual;

wKiom1fPJpWg25M9AAAH4SsM0A8684.png

wKioL1fPJ4zBIgcnAAB73ws_sP8813.png


测试next_day函数,从今天开始算,下下一个星期三是多少号【中文平台】

selectnext_day(next_day(sysdate,'星期三'),'星期三')fromdual;

wKiom1fPJvDRbEiFAAAJjj9jRsI650.png


测试next_day函数,从今天开始算,下一个星期三的下一个星期日是多少号【中文平台】

selectnext_day(next_day(sysdate,'星期日')fromdual;

wKioL1fPJ8mDWaogAAAJ0KKZ-lc092.png


测试last_day函数,本月最后一天是多少号

selectlast_day(sysdate)fromdual;

wKiom1fPKAeAg4y5AAAH4EV3IwU532.png


测试last_day函数,本月倒数第二天是多少号

selectlast_day(sysdate)-1fromdual;

wKioL1fPKDPy1x-3AAAGx6ABI5E113.png


测试last_day函数,下一个月最后一天是多少号

selectlast_day(add_months(sysdate,1))fromdual;

wKiom1fPKHjS65efAAAIAJwovqI861.png


测试last_day函数,上一个月最后一天是多少号

selectlast_day(add_months(sysdate,-1))fromdual;

wKioL1fPKKrCNaIKAAAH2Ioh1ow806.png


注意:

1)日期-日期=天数

2)日期+-天数=日期

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读