oracle 函数、聚焦函数
oracle 常用的函数 以及 聚焦函数
--1,字符函数 --当没有表可以用个的时候oracle自带一个虚表dual -- || 表示连接符号 将字符串连接到一起 式显示 Lower(char):将字符串转化为小写格式 ?将所有员工的名字按小写的方 select lower(ename),lower(job) from emp; Upper(char):将字符转化为大写的格式 select upper('abcd') from dual; Length(char):返回字符串的长度 ?显示正好为5个字符员工的姓名 select * from emp where length(ename)=5; Substr(char,m,n):取字符串的子串,m:表示开始的位置; n:要截取的字符个数 ?显示所有员工姓名的前三个字符 select ename ,substr(ename,1,3) from emp; Trim,Ltrim,Rtrim:去掉查询结果中的空格(全,左,右) select '=='|| trim(' abc ') ||'==' from dual; ?以首字母大写的方式显示所有员工 select ename, substr(ename,0,1)||lower( substr(ename,2,length(ename)-1) ) from emp; Replace (char1,search_string,replace_string): 查询替换 ? 显示所有的员工姓名将A替换成“我是A” select ename, replace(ename,'A','我是A')as result from emp; Instr(char1,char2,[,n[,m]]):取字符串的位置;n:开始位置,m:第m个char2的位置 ? 从第1个字符开始找到员工姓名中第二个A所在的位置 select ename, Instr(ename,'A',1,2) from emp; --2,数学函数 Round(n,[m]):四舍五入。 如果省掉m,则四舍五入到整数;如果m是整数,则四舍五入到小数点后的m位后,如果是m负数,则 四舍五入到小数点m位前 ? 73.2564 四舍五入到小数点后2位 select round(73.2564,2) from dual; trunc(n,[m]):用户截取数字。 如果省略m,就截去小数部分,如果m是整数就截取到小数点后m位后,如果m是负数,则截取到小数点的前m位 ? 73.2564 截取到小数点后3位 select trunc(73.2564,3) from dual; Mod(n,[m]):取模 ? 8%3=? select mod(8,3) from dual; Floor(n):向下取整 ? 7.5846 向下取整 Ceil(n):向上取整 ?7.5846 向上取整 select floor(7.1289) ,Ceil(7.1289) from dual; --2,其他函数 Abs(n) 返回数字n的绝对值 Acos(n) 返回n的反余弦值 Asin(n) 返回n的反正弦值 Atan(n) 返回n的反正切值 Cos(n) 返回n的余弦 Exp(n) 返回e的次幂 Log(m,n) 返回对数 Power(m,n) 返回m的n次幂 --3,日期函数 1 sysdate : 返回系统时间 select sysdate from dual; 2 current_date :返回当前时间 select current_date from dual; 3 Next_day(date,week) :给定时间的下一个星期是几号 /*week 数字和英文*/ select next_day(sysdate,'MONDAY') from dual; 4 add_months(d,n):返回在时间d上加n个月的时间 select add_months( sysdate,12 ) from dual; 5 last_day(d): 返回指定日期所在月份的最后一天 select last_day( sysdate) from dual; 练习: ?查找已经入职362个月多的员工 ?显示满30年份服务年限的员工的姓名和受雇日期 ?每个员工加入公司的天数 ?下个星期一是多少号 ?找出各月倒数第三天受雇的所有员工 --4,转换函数 时间---->字符 字符---->数字 字符---->时间 --4.1、to_char( 时间,格式) --时间格式: yyyy :显示年份 yy :显示年份后2位 mm :月份 dd :号 hh /hh24 :小时 mi :分 ss :秒 Eg:select to_char(sysdate,'yy-mm-dd hh24:mi:ss') from dual; --货币格式: 9 :显示数字 0 :不足则补0 . :显示小数点 ,: 显示分隔符 $ : 显示美元符号 L : 显示本地货币 C : 显示国际货币符号 G : 制定位置显示分割符号 D : 制定位置显示小数点符号 ?薪水指定货币符号 Eg: 8756984.555 $8,756,984.555 $9,999,999.99 L9,999,999.99 select to_char(8756984.5,'L9,999,999.99') from dual; select to_char(8756984.5,'$9G999G999D99') from dual; --4.2、字符转日期 to_date('2010-10-10','yyyy-mm-dd')----------------- Eg: select to_date('2017-2-27','yyyy-mm-dd') from dual; (insert into emp values( 9900, 'ZHANGSAN','CLERK',7698,to_date('2010-10-10','yyyy-mm-dd'),2500.00, 0.00,30);) --4.3、字符转数字 To_number(‘’)------------------------------------- select to_number('')*8 from dual; --5,聚集函数 count,sum,avg,max,min -------------------------------- --5.1、count ---统计总行数 select count(*) from emp; select count(empno) from emp; --统计员工总人数 --5.2、sum-----统计总和 select sum(sal) as total from emp; --统计所有人员的工资总和 --5.3、avg-----统计平均数 select avg(sal) from emp; --统计所有人员的工资平均值 --5.4、max--最大值---min最小值 select max(sal) as maxSal ,min(sal) as minSal from emp; ------聚合函数不能放到where 作为条件 select * from emp where sal avg(sal); --错; select * from emp where sal>(select avg(sal) from emp);---对 --6,显示当前用户- select user from dual; --7,decode 布尔判断函数 ------ --eg:查询出CLERK 的人员数量(如果job是clerk则输出1) select sum( decode(job,'CLERK',1,0) ) from emp; --eg:查询各个工种有多少人 select sum( decode(job,'CLERK',1,0) ) as CLERK, sum( decode(job,'SALESMAN',1,0) ) as SALESMAN, sum( decode(job,'MANAGER',1,0) ) as MANAGER, sum( decode(job,'ANALYST',1,0) ) as ANALYST, sum( decode(job,'PRESIDENT',1,0) ) as PRESIDENT,count(*) as total from emp; --8,nvl(column,default) 非空----------------------------------- --eg:emp表中所有员工在元奖金的基础上增加50元奖金 update emp set comm=nvl(comm ,0 ) +50 ; --如果comm为空,就输出0,不为空就输出本身值
oracle 函数、聚焦函数的更多相关文章
- Oracle 中 decode 函数用法
Oracle 中 decode 函数用法 含义解释:decode(条件,值1,返回值1,值2,返回值2,...值n,返回值n,缺省值) 该函数的含义如下:IF 条件=值1 THEN RETURN(翻译 ...
- 重写Oracle的wm_concat函数,自定义分隔符、排序
oracle中,wm_concat函数是一个聚合函数,和mysql中的group_concat函数类似,不过group_concat函数比较强大,可以定义分隔符和排序,当然所谓强大是相对的,这里假使我 ...
- Oracle日期时间函数大全
ORACLE日期时间函数大全 TO_DATE格式(以时间:2007-11-02 13:45:25为例) Year: yy two digits 两位年 显示值:07 yyy three digits ...
- oracle:sql函数
Oracle将函数大致分为单行函数,聚合函数和分析函数. 单行函数分为字符函数,日期函数,转换函数,数字函数,通用函数,decode函数 一.字符函数 1)大小写控制函数 01.Lower() 全部小 ...
- Oracle过程及函数的参数模式,In、out、in out模式
Oracle过程及函数的参数模式 In.out.in out模式 在Oracle中过程与函数都可以有参数,参数的类型可以指定为in.out.in out三种模式. 三种参数的具体说明,如下图所示: ( ...
- oracle的substr函数的用法
oracle的substr函数的用法 取得字符串中指定起始位置和长度的字符串 substr( string, start_position, [ length ] ) 如: substr( ...
- Oracle nvl(),nvl2()函数介绍
NVL函数 Oracle/PLSQL中的一个函数. 格式为: NVL( string1, replace_with) 功能:如果string1为NULL,则NVL函数返回replace_with的值, ...
- Oracle LPAD/RPAD函数在处理中文时的注意事项
首先看下Oracle官方对函数的定义: The RPAD function returns an expression, right-padded to a specified length with ...
- oracle wm_concat(column)函数的使用
oracle wm_concat(column)函数使我们经常会使用到的,下面就教您如何使用oraclewm_concat(column)函数实现字段合并,如果您对oracle wm_concat(c ...
随机推荐
- Windows ping源码
需要测试外网的联通性,想到了用ping.网上下载了ping的源代码,调试下整理如下: /******************************************************** ...
- Windows 7 繁体中文MSDN原版
Win7 SP1 64位旗舰版繁体版ISO镜像(香港):文件名:hk_windows_7_enterprise_with_sp1_x64_dvd_620688.isoSHA1:82D59B099333 ...
- java性能时间与空间消耗
Java性能时间与空间消耗 一.减少时间消耗 标准代码优化 (1) 将循环不变量的计算移出循环 例如:for (int i=0; i<size()*2; i++) { ... } ------& ...
- .NET 的 WebSocket 开发包比较 【已翻译100%】--网址:http://www.oschina.net/translate/websocket-libraries-comparison-2
编者按 本文出现在第三方产品评论部分中.在这一部分的文章只提供给会员,不允许工具供应商用来以任何方式和形式来促销或宣传产品.请会员报告任何垃圾信息或广告. Web项目常常需要将数据尽可能快地推送给客户 ...
- 区间DP 等腰三角形
题目描述:给定一个正N边形,可以通过连线将这个多边形分割成N-2个三角形,问这N-2个三角形中恰有k个等腰三角形的分割方法有多少?这个值可能很大,输出对9397取模的结果.数据范围:n,k <= ...
- 聊聊Spring中的工厂
BeanFactory是Spring IOC容器的根接口,定义了Bean工厂的最基础的功能特性,比如根据name获取指定bean等,根据不同用途它的子接口又对它的功能进行细化,比如是否是可列表的,是否 ...
- Laravel 新增的Switch模板控制语句非常不错
切换语句switch语句可以使用来构建,,,和指令:@switch@case@break@default@endswitch @switch($i) @case(1) First case... @b ...
- 3.1-3.5 分布式部署hadoop2.x的准备和配置
一.环境 192.168.1.130 master 192.168.1.131 slave1 192.168.1.132 slave2 所有主机: 1.关闭防火墙.selinu ...
- Get back Typing Break in Ubuntu 12.04 & 11.10(转载)
转自:http://ubuntuguide.net/get-back-typing-break-in-ubuntu-12-04-11-10 Since Ubuntu 11.10 Oneiric, th ...
- E20180407-hm
queue n. (人或车辆) 行列,长队; 辫子; vi. (人.车等) 排队等候; vt. (使) 排队,列队等待; compatible adj. 兼容的,相容的; 和谐的,协调的 ...