Oracle单组函数
--Upper -------把字符转换成大写
SELECT Upper ('abcde') FROM dual ;
--Lower ----- 把字符转换成小写
SELECT lower('ABCDE') FROM dual ;
--Initcap -----返回所有单词的首字母大写,其他字母小写
Select initcap(ename) from emp;
--Concat -----字符串连接 ,相当于||
Select concat('a','b') from dual;
Select 'a' || 'b' from dual;
--Substr -------查找字符串
Select substr('abcde',length('abcde')-2) from dual;
Select substr('abcde',-3,3) from dual;
substr(string,position,substring_length)
1、如果position=0, 则被当做1
2、如果position>1, 则从position位置开始找
3、如果position<1, 则从结尾开始找
4、如果第三个位置没有指定,则从指定位置到结尾
--Length ------字符串的长度
Select length(dname) from dept;
--Replace -----字符串替换
Select replace(ename,'a','A') from emp;
--Instr -- -----字符串查找,返回索引值
Select instr('Hello World','or') from dual; --8 indexof
--Lpad ------左侧填充
select lpad('Smith',10,'*') from dual--左侧填充 *****Smith
--Rpad ------右侧填充
select rpad('Smith',10,'*') from dual--右侧填充 Smith*****
--Trim -------过滤首位空格
select trim(' Mr Smith ') from dual --过滤首尾空格 Mr Smith
--数值函数
--Round -----四舍五入,取精度
select round(462,-2) from dual; ------负数往小数点前数 ----500
select round(412.313,2) from dual; -----正数往小数点后数 ----412.13
--Trunc -----不四舍五入,直接取最大值
select trunc(462.13,-2) from dual; ----400
--日期函数
--Months_between() -----两个时间之间隔了多少个月
select months_between(sysdate,hiredate) from emp;
--Add_months() ------在某个时间点上加一个月
select add_months(sysdate,1) from dual;
--Next_day()
select next_day(sysdate,'星期一') from dual; ----返回下一个星期一的日期
--Last_day
select last_day(sysdate) from dual; ----返回这个月的最后一天
--转换函数
--To_char
select to_char(sysdate,'yyyy') from dual; ---2011
select to_char(sysdate,'yyyy-mm-dd') from dual; ----2011-07-16
select to_char(sal,'L999,999,999') from emp; ----
select to_char(sysdate,'D') from dual; --返回星期 ----7
--To_number
select to_number('13')+to_number('14') from dual; ------27
--To_date
Select to_date('2009-02-10','yyyy-MM-dd') from dual; ----2009/2/10
select to_char('001') from dual; ----001
select to_number('003')from dual; -----3
--通用函数
--NVL()函数 -----有值返回本身,无值返回0
select nvl(comm,0) from emp;
--NULLIF()函数 ----如果表达式 exp1 与exp2 的值相等则返回 null,否则返回 exp1 的值
nullif(exp1,exp2)
--NVL2()函数
select empno, ename, sal, comm, nvl2(comm, sal+comm, sal) total from emp; ----如果comm不为null,返回sal+comm,否则返回comm
--COALESCE()函数 --依次考察各参数表达式,遇到非null值即停止并返 回该值。
select empno, ename, sal, comm, coalesce(sal+comm, sal, 0)总收入 from emp;
--CASE表达式
select empno, ename, sal,
case deptno
when 10 then '财务部'
when 20 then '研发部'
when 30 then '销售部'
else '未知部门'
end 部门
from emp;
--DECODE()函数 --和 case表达式类似,decode()函数也用于实现多路分支结构
select empno, ename, sal,
decode(deptno, 10, '财务部',
20, '研发部',
30, '销售部',
'未知部门')
部门
from emp;
case在SQL中有两种写法,先建立一个表
create table salgrade(grade int, sal int);
insert into salgrade values(1,1000);
insert into salgrade values(2,2000);
insert into salgrade values(3,3000);
第一种写法,简单写法:
select grade,sal,
case grade
when 1 then 'low'
when 2 then 'middle'
else 'high'
end
from salgrade;
第二种写法,查找写法:
SELECT grade,sal,
case when sal <=1000 then 'low'
when sal <=2000 then 'middle'
else 'high'
end
FROM salgrade;
decode只能代替第一种写法:
select grade,sal,decode(grade,1,'low',2,'middle','high') from salgrade;
--单行函数嵌套
select empno, lpad(initcap(trim(ename)),10,' ') name, job, sal from emp;
Oracle单组函数的更多相关文章
- oracle常用函数总结(二)
之前也有写过“oracle常用函数总结(一)”,为了尽量找全常见oracle函数,笔者特意查找了相关资料来作为参考,下边给大家罗列出来,部分和之前有重复的,希望能帮到大家! 列举了31个函数和1个分组 ...
- oracle add_months函数
oracle add_months函数 add_months 函数主要是对日期函数进行操作,举例子进行说明 add_months 有两个参数,第一个参数是日期,第二个参数是对日期进行加减的数字(以月为 ...
- Oracle to_date()函数的用法
Oracle to_date()函数的用法 to_date()是Oracle数据库函数的代表函数之一,下文对Oracle to_date()函数的几种用法作了详细的介绍说明,供您参考学习. 在Orac ...
- Oracle over函数
Oracle over函数 SQL code: sql over的作用及用法RANK ( ) OVER ( [query_partition_clause] order_by_clause )DE ...
- Oracle常用函数
前一段时间学习Oracle 时做的学习笔记,整理了一下,下面是分享的Oracle常用函数的部分笔记,以后还会分享其他部分的笔记,请大家批评指正. 1.Oracle 数据库中的to_date()函数的使 ...
- Oracle SQL函数
Oracle将函数大致分为单行函数,聚合函数和分析函数. 单行函数分为字符函数,日期函数,转换函数,数字函数,通用函数,decode函数 一.字符函数 1)大小写控制函数 01.Lower() 全部小 ...
- Oracle trunc()函数的用法
Oracle trunc()函数的用法 /**************日期********************/1.select trunc(sysdate) from dual --2013-0 ...
- oracle中函数和存储过程的区别和联系【转载竹沥半夏】
oracle中函数和存储过程的区别和联系[转载竹沥半夏] 在oracle中,函数和存储过程是经常使用到的,他们的语法中有很多相似的地方,但也有自己的特点.刚学完函数和存储过程,下面来和大家分享一下自己 ...
- 转,Oracle中关于处理小数点位数的几个函数,取小数位数,Oracle查询函数
关于处理小数点位数的几个oracle函数() 1. 取四舍五入的几位小数 select round(1.2345, 3) from dual; 结果:1.235 2. 保留两位小数,只舍 select ...
随机推荐
- Hamilton回路的判定与构造
定理1:在一个具有n个顶点的无向连通图G中,如果任意两个顶点的度数之和大于n,则G具有Hamilton回路.此条件为充分条件 定理2:设图G = <V,E>,是Hamilton图,则对于v ...
- 我的Unity学习路线
前言 上班的时间内都很忙在做项目,休息时间里闲下来了,却觉得没什么事做不自在.难道真是苦逼的命不会享受? 想了一下这一段时间以来的过程:先是重新看了一遍Unity的基础部分,然后买了<3D数学基 ...
- 迷你DVD管理器项目
package chapter5; import java.util.*; public class MiniDVD { public static void main(String[] args){ ...
- 谈谈redis主从复制的重点
Redis主从复制的配置十分简单,它可以使从服务器是主服务器的完全拷贝.下面是关于Redis主从复制的几点重要内容: Redis使用异步复制.但从Redis 2.8开始,从服务器会周期性的应答从复制流 ...
- iOS开发——网络编程Swift篇&Alamofire详解
Alamofire详解 预览图 Swift Alamofire 简介 Alamofire是 Swift 语言的 HTTP 网络开发工具包,相当于Swift实现AFNetworking版本. 当然,AF ...
- ST3插件——PlainTasks的使用
今天看到一个有意思的ST3插件,可以进行简单的任务管理. 安装很简单:ctrl + shift + p,输入install回车,再输入plaintasks回车即可. 以下是一些支持的操作,更多的操作请 ...
- trac项目管理平台
本文来自百科,由于是非Python开发者,所以仅为了拓宽知识面 1软件介绍 Trac是一个为软件开发项目需要而集成了Wiki和问题跟踪管理系统的应用平台,是一个开源软件应用.Trac以简单的方式建立了 ...
- FusionCharts参数的详细说明和功能特性(转)
功能特性animation 是否动画显示数据,默认为1(True)showNames 是否显示横向坐标轴(x轴)标签名称ro ...
- 在Sql Server 中使用正则表达式
CREATE FUNCTION dbo.find_regular_expression ( ), --需要匹配的源字符串 ), --正则表达式 --是否区分大小写,默认为false ) RETURNS ...
- php基础23:数值与数值函数
<?php //1.自动转换 $a = 5; $b = "5a"; $c = $a + $b; echo $c; echo "<br>"; $ ...