Oracle系列:(8)单行函数
admin
2023-05-01 20:43:27
0




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

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


测试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;

Oracle系列:(8)单行函数


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

Oracle系列:(8)单行函数


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

select length('hello你好') from dual; 
select lengthb('hello你好') from dual;

Oracle系列:(8)单行函数

 


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

select instr('helloworld','o') from dual;

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

select LPAD('hello',10,'#') from dual;
select RPAD('hello',10,'#') from dual;

Oracle系列:(8)单行函数


测试trim/replace函数

select trim(' ' from '  he  ll                ') from dual;
select replace('hello','l','L') from dual;

Oracle系列:(8)单行函数


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

select round(3.1415,3) from dual;
select trunc(3.1415,3) from dual;
select mod(10,3) from dual;

Oracle系列:(8)单行函数



当前日期:

 select sysdate from dual;

Oracle系列:(8)单行函数



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

select round(sysdate,'month') from dual;

Oracle系列:(8)单行函数


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

select round(sysdate,'year') from dual;

Oracle系列:(8)单行函数


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

select trunc(sysdate,'month') from dual;

Oracle系列:(8)单行函数


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

select trunc(sysdate,'year') from dual;

Oracle系列:(8)单行函数


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

select sysdate-1 "昨天",sysdate "今天",sysdate+1 "明天" from dual;

Oracle系列:(8)单行函数


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

select ename "姓名",round(sysdate-hiredate,0)/365 "工龄" from emp;

Oracle系列:(8)单行函数



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

select months_between('31-12月-16',sysdate) from dual;

Oracle系列:(8)单行函数


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

select ename "姓名",months_between(sysdate,hiredate) "精确月工龄" from emp;

Oracle系列:(8)单行函数


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

select add_months(sysdate,1) from dual;

Oracle系列:(8)单行函数


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

select add_months(sysdate,-1) from dual;

Oracle系列:(8)单行函数


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

select next_day(sysdate,'星期三') from dual;

Oracle系列:(8)单行函数

Oracle系列:(8)单行函数


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

select next_day(next_day(sysdate,'星期三'),'星期三') from dual;

Oracle系列:(8)单行函数


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

select next_day(next_day(sysdate,'星期三'),'星期日') from dual;

Oracle系列:(8)单行函数


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

select last_day(sysdate) from dual;

Oracle系列:(8)单行函数


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

select last_day(sysdate)-1 from dual;

Oracle系列:(8)单行函数


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

select last_day(add_months(sysdate,1)) from dual;

Oracle系列:(8)单行函数


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

select last_day(add_months(sysdate,-1)) from dual;

Oracle系列:(8)单行函数


注意:

1)日期-日期=天数

2)日期+-天数=日期







相关内容

热门资讯

日本零食厂商因石脑油匮乏部分停... 【环球网报道】据日本共同社5月13日报道,日本食品生产公司“野村煎豆加工店”当天接受采访时表示,由于...
郑丽文:特朗普若反对“台独”,... 美国总统特朗普将于5月13日至15日访华,台湾问题是主要议题之一。中国国民党主席郑丽文称,特朗普若表...
特朗普要求中国对美经贸团队访问... 澎湃新闻记者 杨文钦 朱郑勇5月13日,外交部发言人郭嘉昆主持例行记者会。法新社记者提问,美国总统特...
美媒又想起这茬:2年前在地中海... 【文/观察者网 阮佳琪】2024年12月23日,载有16名船员的俄罗斯“大熊星座”号货船在西班牙近海...
App过度索取授权或被境外间谍... 微信公众号“国家安全部”5月13日发文: 手机里各种各样的应用程序(APP)五花八门,在方便我们生...
广合科技获得发明专利授权:“一... 证券之星消息,根据天眼查APP数据显示广合科技(001389)新获得一项发明专利授权,专利名为“一种...
华尔街科技老将:大科技公司分化... 5月11日,互联网泡沫时期的知名芯片分析师、Niles Investment Management创...
香港80后“地产女王”烧炭身亡... 据《香港01》报道,5月12日,香港九龙传统豪宅地段加多利山畔的豪宅项目Kadoorie Hill发...
谷歌发布安卓 AI 系统,这就... 和去年一样,在正式的 Google I/O 开发者大会之前,谷歌为 Android 单独开了一次小型...
300斤医生走红 曾一年猛涨1...   300斤医生走红 曾一年猛涨100斤  【300斤医生走红 曾一年猛涨100斤】5月11日,上海...