oracle非常量不能用于privot_Oracle(二)

本文详细介绍了Oracle数据库中的各种函数,包括单行函数如lower/upper/initcap,多行函数如concat/substr,以及日期处理函数如round/trunc/mod。还探讨了日期类型的操作,如next_day、last_day以及months_between。此外,文章还讲解了数据类型转换、隐式转换、多表查询和子查询的使用,展示了如何在实际操作中应用这些函数和技巧。
摘要由CSDN通过智能技术生成

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

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

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

select lower('www.BAIdu.C') from dual;

select upper('www.BAIdu.C') from dual;

select initcap('www.BAIdu.C') from dual;

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

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

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

select length('我是中国人') from dual; 5

select lengthb('hello你好') from dual; 中文占2

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

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

注意:找不到返回0

大小写敏感

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

select lpad('hello',10,'*') from dual;

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

5.测试trim/replace函数

select trim(' ' from ' he ll') from dual; 其它地方是去空格的

select trim('h' from 'helloworld') from dual;

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

select replace ('abcd','b','s') from dual;

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

select round(3.1415,3) from dual; 四舍五入

select trunc(3.1415,3) from dual; 截取

truncate 表名 delete from 表名

select mod(10,3) from dual; 取余数

7.当前日期:sysdate= 26-4月-15

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

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

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

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

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

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

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

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

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

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

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

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

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

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

select months_between('01-9月-95','11-11月-94') from dual;

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

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

select ADD_MONTHS ('11-1月-94',6)from dual;

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

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

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

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

16.测试next_day函数,从今天开始算,下一个星期三是多少号

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

17.测试next_day函数,从今天开始算,下下一个星期三是多少号

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

18.测试next_day函数,从今天开始算,下一个星期三的下一个星期日是多少号

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

select NEXT_DAY ('01-9月-95','星期五') from dual; 月和星期三五得用中文

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

select last

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值