Oracle---函数
Oracle---函数
注意
本博文仅供学术研究和交流参考,严禁将其用于商业用途。如因违规使用产生的任何法律问题,使用者需自行负责。
--单行函数 --字符函数 --lover 将字符全部转为小写
select ename,lower(ename) from emp;
data:image/s3,"s3://crabby-images/ec150/ec1502eb43b5b58b8c0790f2ce416693f6cf42cd" alt=""
select ename from emp where lower(ename) like '%s%';
data:image/s3,"s3://crabby-images/9ac78/9ac784531c49a8a97a8ec68ba3b21a9e1fe1aaf5" alt=""
--upper 将字符全部转为大写
select upper(ename) from emp;
data:image/s3,"s3://crabby-images/566fa/566fa2d30ac595bb44816c9bc69022e7841f5c55" alt=""
select ename from emp where upper(ename) like '%s%';
data:image/s3,"s3://crabby-images/45dba/45dbab4af97f0be8d04d23e600459bf28e0cfb61" alt=""
--initcap--将字符首字母转为大写,其它字母变成小写
select initcap(ename) from emp;
data:image/s3,"s3://crabby-images/4a251/4a2512848b17647c3e70f203add484ebfcb3d5b4" alt=""
select 'Sql course',initcap('sql sourse') from dual;--dual伪表
data:image/s3,"s3://crabby-images/6cb25/6cb256bb372e689e73fb4e3bb6babadb60f9cc84" alt=""
--concat 连接两个值 等同于 ||
select ename || '的工资是' || sal from emp;
select concat(concat(ename,'的工资是'),sal) from emp;
-- substr --截取字符串子串,默认下标1开始
select 'wuyuehong@qq.com',substr('wuyuehong@qq.com',3),
substr('wuyuehong@qq.com',10,3) from dual;
data:image/s3,"s3://crabby-images/93c54/93c54dde4de2b0569bf4c9755e12085636fbcd6f" alt=""
--length -- 取字符串长度
select ename,length(ename) from emp;
data:image/s3,"s3://crabby-images/39d20/39d208f900c803ca1525820c715d2a2788532fe2" alt=""
--1.写一个查询,用首字母大写,其它字母小写显示雇员的 ename,显 --示名字的长度,并给每列一个适当的标签,条件是满足所有雇员名字 --的开始字母是J、A 或 M 的雇员,并对查询结果按雇员的ename升序 --排序。
select initcap(ename) 首字母大写, length(ename) 名字长度
from emp
where initcap(ename) like 'J%' or initcap(ename) like 'A%' or initcap(ename) like 'M%'
order by ename;
data:image/s3,"s3://crabby-images/456ed/456edbe7777be218cfd69f5aedf7da07b89cbf37" alt=""
--字符处理函数 -- instr 参数 一是目标字符串,参数二子串,参数三开始索引,参数四 第几次出现
select 'wuyuehong@qq.com',
instr('wuyuehong@qq.com','@',9),
instr('wuyuehong@qq.com','.',1,2) from dual;
data:image/s3,"s3://crabby-images/4aa8e/4aa8e2a8ec7a378a65d5aa83bfc192020486ee66" alt=""
--lpad--补充字符串(左) --参数一 目标字符串,参数二 返回字符长度 参数三 填充字符串
select ename,lpad(ename,10,'aa'),length(ename) from emp;
data:image/s3,"s3://crabby-images/1d084/1d08445c16266bf24a4a4b7352302abbb1034506" alt=""
--rpad--被充字符串(右)
select ename,rpad(ename,10,'aa'),rpad(ename,10,'aa'),length(ename) from emp;
--trim()--默认去字符串首尾空格 --去掉指定字符串,默认去掉首尾指定子串
select ' sql sourse ',trim(' sql sourse ') from dual;
data:image/s3,"s3://crabby-images/9960c/9960c5d2fde3263adb8c08faf11d6fb13294b485" alt=""
select 'hsql sourseh',trim('h' from 'hsql sourseh') from dual;
data:image/s3,"s3://crabby-images/5af7d/5af7dd1261b5ce45eede9607e88da23fb38cb3ab" alt=""
select 'hsql sourseh',trim(both 'h' from 'hsql sourseh') from dual;
data:image/s3,"s3://crabby-images/da217/da217209cc50ff9a22542c492634a92263ad2dc1" alt=""
select 'hsql sourseh',trim(leading 'h' from 'hsql sourseh') from dual;
data:image/s3,"s3://crabby-images/6d734/6d734ed5944050cd57e252409cef46138507c746" alt=""
select 'hsql sourseh',trim(trailing 'h' from 'hsql sourseh') from dual;
data:image/s3,"s3://crabby-images/5c3a9/5c3a9d65f2dd2377738bae02df4aef175841d707" alt=""
--replace 字符替换函数 --REPLACE(s1,s2,s3) --参数一 目标字符串 参数二目标字符子串 参数三替换字符串
select 'hsql sourseh',replace('hsql sourseh','hs','a') from dual;
data:image/s3,"s3://crabby-images/1b528/1b528c5c5b0736176cfb92a7b5816f7ee81a02f7" alt=""
select 'hsql sourseh',replace('hsql sourseh',' ','') from dual;
data:image/s3,"s3://crabby-images/594f0/594f0b2a51acffc5e694a6c350e115884671dac0" alt=""
--1.查询员工姓名中中包含大写或小写字母A的员工姓名。
--2.查询部门编号为10或20,入职日期在81年5月1日之后, --并且姓名中包含大写字母A的员工姓名,员工姓名长度(提示,要求使用INSTR函数,不能使用like进行判断)
select * from emp where
deptno in(10,20) and instr(ename,'A') != 0;
data:image/s3,"s3://crabby-images/f1986/f1986194939160a7bc7b10df0ea265ca11e744c8" alt=""
select ename,length(ename) from emp
where instr(ename,'A') > 0 and hiredate > '01-5月-81' and deptno in(10,20);
data:image/s3,"s3://crabby-images/9b106/9b1067acc8634e65caa17254c06285010541b3b4" alt=""
--3.查询每个职工的编号,姓名,工资 --要求将查询到的数据按照一定的格式合并成一个字符串. --前10位:编号,不足部分用填充,左对齐 --中间10位:姓名,不足部分用填充,左对齐 --后10位:工资,不足部分用*填充,右对齐
--数值函数 --round 四舍五入 -- 参数一目标数值 参数 保留多少位
select 45.926,round(45.926)
,round(45.926,2),
round(45.926,0),
round(45.926,-1),
round(45.926,-2) from dual;
data:image/s3,"s3://crabby-images/b1b38/b1b38285c231c27e6ba6bfb54f7459f32913fa2d" alt=""
--trunc()截取-- 参数一目标数值 参数 保留多少位
select 45.926,trunc(45.926),
trunc(45.926,2),
trunc(45.926,0),
trunc(45.926,-1),
trunc(45.926,-2) from dual;
data:image/s3,"s3://crabby-images/200b3/200b3f914140eb2d54dd8afacc8ac8fc621eb833" alt=""
--mod 取余数 ,取模
select 12,mod(12,5) from dual;--2
data:image/s3,"s3://crabby-images/5ddb5/5ddb59f14b0537972d9f27f79c6c50b5b23d3ebe" alt=""
--日期函数 --sysdate返回当前系统日期
select sysdate from dual;
data:image/s3,"s3://crabby-images/1b9dc/1b9dc6a761f2c3f7397b78f3853ef45927258a61" alt=""
--日期的运算 --加减 后面数值默认是天
select sysdate+2 from dual;
data:image/s3,"s3://crabby-images/3040f/3040f5f439157c33981625cb7747da234326ea68" alt=""
select sysdate-180 from dual;
data:image/s3,"s3://crabby-images/370c9/370c9958bff75dcc155b8a2e7fdfea1153234833" alt=""
--1.查询每个员工截止到现在一共入职多少天? --2.当前日期为2015年,指定日期格式为DD-MON-RR,指定日期为01-1月-01,该日期实际所代表的日期为?
--3.当前日期为2015年,指定日期格式为DD-MON-RR,指定日期为01-1月-95,该日期实际所代表的日期为?
--4.当前日期为1998年,指定日期格式为DD-MON-RR,指定日期为01-1月-01,该日期实际所代表的日期为?
--5.当前日期为1998年,指定日期格式为DD-MON-RR,指定日期为01-1月-95,该日期实际所代表的日期为?
--6.当前日期为2015年,指定日期格式为DD-MON-YY,指定日期为01-1月-01,该日期实际所代表的日期为?
--7.当前日期为1998年,指定日期格式为DD-MON-YY,指定日期为01-1月-95,该日期实际所代表的日期为? --months_between 返回两个日期类型数据之间间隔的自然月数
select months_between(hiredate,sysdate),
months_between(sysdate,hiredate) from emp;
data:image/s3,"s3://crabby-images/3fb1f/3fb1fbffd44ee81c352e5e311ee5dffece859841" alt=""
--add_months 添加月数
select hiredate,add_months(hiredate,6) as 转正日期 from emp;
data:image/s3,"s3://crabby-images/0776c/0776c7847e84a6408bd45dea3f7d95f0dbcbb6f2" alt=""
--next_day
select next_day(sysdate,'星期二') from emp;
data:image/s3,"s3://crabby-images/21859/21859e08a4568f700267945d3d1b8158d5032d05" alt=""
--last_day 返回指定日期当月最后一天的日期
select last_day('01-2月-81') from dual;
data:image/s3,"s3://crabby-images/edc6f/edc6f7bbaa47eb127c619dce8786fac4bf7f1ab8" alt=""
--round(date,fmt) 按照指 定格式四舍五入获得日期
select hiredate,round(hiredate,'MM') from emp;--按月份四舍五入 找天 大于15月份加1
data:image/s3,"s3://crabby-images/9fb96/9fb968d2fbfbcbcab8d72fc3f11dd242929ec6c4" alt=""
select hiredate,round(hiredate,'YY') from emp;--按照年四舍五入 找月 大于6年加1
data:image/s3,"s3://crabby-images/f15de/f15de5bb347a7d590db0083e43e1ffa3b3d0d611" alt=""
select hiredate,round(hiredate,'DD') from emp;--按照日四舍五入
data:image/s3,"s3://crabby-images/f3b21/f3b21d1fe36a6985276f00162363fd38ecfa30c2" alt=""
--trunc(data,fmt)截取日期 按照指定格式 截取获得日期
select hiredate,trunc(hiredate,'MM') from emp;
data:image/s3,"s3://crabby-images/26239/2623985c85d80d5900507d743e6bc17ca027e98e" alt=""
select hiredate,trunc(hiredate,'YY') from emp;
data:image/s3,"s3://crabby-images/b4a8a/b4a8a63ed534e4ba0408d240c82bc33fea40f759" alt=""
select hiredate,trunc(hiredate,'DD') from emp;
data:image/s3,"s3://crabby-images/ad6cf/ad6cfa3a683bc014bf90352c8b4716c170fb80cf" alt=""
--extract 抽取指定格式日期year month
select sysdate,extract(month from sysdate) from emp;
data:image/s3,"s3://crabby-images/2afb3/2afb3db196379673faaa908b706eab6798a36471" alt=""
--1.查询服务器当前时间
select sysdate from dual;
data:image/s3,"s3://crabby-images/4b899/4b899eaf204b2caa37c08051304e6ef700882d8c" alt=""
--2.查询部门10,20的员工截止到2000年1月1日,工作了多少个月, --入职的月份。(提示:使用months_between,extract)
select hiredate as 入职日期,
extract(month from hiredate) as 入职月份,
months_between('01-1月-00',hiredate) as 工作月份
from emp where deptno in(10,20);
data:image/s3,"s3://crabby-images/03a6f/03a6fec5ede202df473f7a0d95c6990e94640255" alt=""
--3.如果员工试用期6个月,查询职位不是MANAGER的员工姓名, --入职日期,转正日期,入职日期后的第一个星期一,入职当月的最后一天日期。 --(提示:使用add_months,next_day,last_day)
select ename as 员工姓名,
hiredate as 入职日期,
add_months(hiredate,6) 转正日期,
next_day(hiredate,'星期一') as 入职日期后的第一个星期一,
last_day(hiredate)as 入职当月的最后一天日期
from emp where job not in('MANAGER');
data:image/s3,"s3://crabby-images/dd861/dd86146a905fcf818a11a183ecd1b1daca65b518" alt=""
select ename 员工姓名, hiredate 入职日期, add_months(hiredate,6) 转正日期,next_day(hiredate,'星期一') 第一个星期一, last_day(hiredate) from emp where job <> 'MANAGER';--kaiqingli
data:image/s3,"s3://crabby-images/d35eb/d35eb748762b43e2702b29d66c157a14ad99ed8a" alt=""
--转化函数 --隐式转换
select sal,sal+12.0 from emp;
data:image/s3,"s3://crabby-images/c0f77/c0f772357c30dadea50c72bad0927447aadbf400" alt=""
select sal,sal+'10' from emp;
data:image/s3,"s3://crabby-images/a051e/a051e8cf6582dc6f2ae7e62a30ae89193aef7b37" alt=""
--显示转换 --to_char 日期转为字符类型
select hiredate,to_char(hiredate,'yy-mm-dd') from emp;
data:image/s3,"s3://crabby-images/1a09b/1a09b84c1083737d4f7b18c24f6a48e2404d2b00" alt=""
select hiredate,to_char(hiredate,'yyyy-mm-dd') from emp;
data:image/s3,"s3://crabby-images/ebd05/ebd051867de177d62289abe730ce949305ba18b6" alt=""
select hiredate,to_char(hiredate,'yyyy/mm/dd') from emp;
data:image/s3,"s3://crabby-images/77ad1/77ad1028564e16c4b29ffde7baa24f34d379c02b" alt=""
select hiredate,to_char(hiredate,'yyyy"年"mm"月"dd"日"') from emp;
data:image/s3,"s3://crabby-images/01268/01268dd535eda6b727671b937e71ac96ca35b966" alt=""
select hiredate,to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') from emp;
data:image/s3,"s3://crabby-images/74d59/74d5952f73acc4d3ff659732bca86748204553cf" alt=""
select hiredate,to_char(sysdate,'yyyy-mm-dd hh12:mi:ss') from emp;
data:image/s3,"s3://crabby-images/f47e0/f47e0a8923a7cb5493a85c3f2bd59b2471203880" alt=""
--to_char 用于数值型
select 12343434.789 from dual;
data:image/s3,"s3://crabby-images/9c8c5/9c8c506fa90a62cec037b56d55260cc53b152251" alt=""
select to_char('$12343434.789') from dual;
data:image/s3,"s3://crabby-images/3f5ae/3f5ae407d09f8d335dfebe1b0ec4d8da82ac9a38" alt=""
--to_number 字符内型转换为数值类型
select saL,sal+'10' from emp;--隐式转换
data:image/s3,"s3://crabby-images/8fb58/8fb5837e03496544052951488a462472755a6eb8" alt=""
select to_number('123.4')+3 from dual;--显示转换
data:image/s3,"s3://crabby-images/f5fb3/f5fb3e090a155d9c1878b770863c22da27ea5f88" alt=""
--to_date 字符类型转为日期类型
select to_date('2018-03-01','YY/MM/DD') from dual;
data:image/s3,"s3://crabby-images/c0e17/c0e17ca69df7f0f6e7b208335b18096671664dd1" alt=""
--1.显示服务器系统当前时间,格式为2007-10-12 17:11:11(提示:使用to_char函数)
select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') from emp;
data:image/s3,"s3://crabby-images/c55eb/c55eb73ab69a1f99a85a06406673ed562acdd786" alt=""
--2.显示ename、hiredate 和 雇员开始工作日是星期几,列标签DAY(提示:使用to_char函数)
select ename as 员工姓名,
hiredate as 入职日期,
to_char(hiredate,'day') as day
from emp;
data:image/s3,"s3://crabby-images/17944/17944d6dc7dc00cdc900d9851756dff0d55936f7" alt=""
--3.查询员工姓名,工资,格式化的工资(¥999,999.99) (提示:使用to_char函数)
select ename,sal,
from emp;
--4.把字符串2015-3月-18 13:13:13 转换成日期格式,并计算和系统当前时间间隔多少天。 (提示:使用to_date函数)
select to_date('2015-3月-18 13:13:13','YY-MM"月"-DD hh24:mi:ss'),
trunc(sysdate - to_date('2015-3月-18 13:13:13','YY-MM"月"-DD hh24:mi:ss'))
--通用函数 --nvl 参数一目标对象 参数二替代值
select comm,nvl(comm,0) from emp;
data:image/s3,"s3://crabby-images/e45c0/e45c0f882952439e34411f1d6db740d1f8e16143" alt=""
-- nvl2 参数一目标对象 参数二 参数三代替值
select comm,nvl2(comm,'有奖金',0) from emp;
data:image/s3,"s3://crabby-images/7f63a/7f63ae2f4035b873840e4c072daa20762f79ae7d" alt=""
select comm,nvl2(comm,'有奖金','无') from emp;
data:image/s3,"s3://crabby-images/03722/03722ea025704aadb02e39a026f1773c586f8668" alt=""
--nullif 参数一与参数二进行比较如果相等返回空,否则返回参数一 --参数一与参数二类型必须一致
select nullif(1,'1') from dual;--数值类型不一致
select nullif(1,1) from dual;--null
select nullif(1,2) from dual;--1
data:image/s3,"s3://crabby-images/d49c8/d49c8d4225c2e460f384c3476cf18cece68fd4e5" alt=""
--coalesce函数
select coalesce(123) from dual;--函数没有足够的参数
data:image/s3,"s3://crabby-images/a2d9c/a2d9cf04468371e6980f6673e957cb4862bb02ef" alt=""
select coalesce(null,null,3,4,2) from dual;
data:image/s3,"s3://crabby-images/3716b/3716b8f91144a74a57dc980c77279a589c99015e" alt=""
select coalesce(null,null,comm,4,2) from emp;
data:image/s3,"s3://crabby-images/e8037/e8037fb13a284ddb43218dbb83f59ba3d4055b7b" alt=""
--case --decode用来进行条件判断输出映射结果
select * from emp;
select ename,hiredate,deptno, case deptno when 10 then '研发部' when 20 then '生产部'
when 30 then '财务部' else '无' end as 部门 from emp;
--decode
select ename,hiredate,deptno,
decode(deptno,10,'研发部',20,'生产部',30,'财务部','无') as 部门
from emp;
data:image/s3,"s3://crabby-images/41953/4195375bc35d09bb28a82922a8a7b24c5535da2c" alt=""
--函数嵌套 --注意:函数的嵌套最里的那一层先执行
select ename,nvl(to_char(mgr),'无经理') from emp;
data:image/s3,"s3://crabby-images/ad1d7/ad1d7235cbd6c887e073d46f616b32f8ae42fbcf" alt=""
--1.计算2000年1月1日到现在有多少月,多少周(四舍五入)。
select months_between(sysdate,'01-1月-00') as 月,
round(months_between(sysdate,'01-1月-00')*30/7) as 周
from dual;
data:image/s3,"s3://crabby-images/488f2/488f2b4227f8bbf78065e1f1a95052568f4ce613" alt=""
--2.查询员工ENAME的第三个字母是A的员工的信息(使用2个函数)。
select * from emp where ename like '__A%';
data:image/s3,"s3://crabby-images/2cae0/2cae0d737b5719e01d68cd757171790881e16599" alt=""
--3.使用trim函数将字符串‘hello’、‘ Hello ’、‘bllb’、‘ hello
-- ’分别处理得到下列字符串ello、Hello、ll、hello。
select trim('h' from 'hello'),
trim(' ' from ' Hello '),
trim('b' from 'bllb'),
trim(' ' from ' hello ')
from dual;
data:image/s3,"s3://crabby-images/6ddff/6ddff4a5fd8ebc932d7398f4d4c122184fca5f6c" alt=""
--4.将员工工资按如下格式显示:123,234.00 RMB 。
select ename,sal,to_char(sal,'$99,99.99') from emp;
data:image/s3,"s3://crabby-images/308a3/308a3c1c4ba62e90de2e9ad84be9c3502ef6c0e9" alt=""
--5.查询员工的姓名及其经理编号,要求对于没有经理的显示“No Manager”字符串。
select ename,mgr,nvl(to_char(mgr),'NO Manager') from emp;
data:image/s3,"s3://crabby-images/074d0/074d089a054a1e49a8983af6ad5ab81d832785f4" alt=""
--6.将员工的参加工作日期按如下格式显示:月份/年份。
--7.在员工表中查询出员工的工资,并计算应交税款: --如果工资小于1000,税率为0,如果工资大于等于1000并小于2000, --税率为10%,如果工资大于等于2000并小于3000,税率为15%,如果工资大于等于3000,税率为20%。
select sal,ename,
case
when sal<1000 then 0
when sal >= 1000 and sal < 2000 then (sal-1000)*0.1
when sal >= 2000 and sal < 3000 then 1000*0.1 + (sal - 2000) * 0.15
when sal >= 3000 then 1000*0.1 + 1000*0.15+(sal-3000)*0.2
end as 税收
from emp;
data:image/s3,"s3://crabby-images/5b083/5b0833470ab1d9130c51c27d27bfa089719d0fd0" alt=""
--8.创建一个查询显示所有雇员的 ename和 sal。格式化sal为 15 个字符长度,用 $ 左填充,列标签 SALARY。
select * from emp;
分割线
相关信息
以上就是我关于 Oracle---函数 知识点的整理与总结的全部内容,希望对你有帮助。。。。。。。