Oracle中的单行函数

1 字符函数

UPPER()--将字符串转换为大写

SELECT UPPER('abc') FROM dual;

LOWER()-将字符串转换为小写

SELECT LOWER('ABC') FROM dual;

INITCAP()-首字母大写,其它字母小写.

SELECT INITCAP('hello') FROM dual;

REPLACE()-将指定的字符/字符串替换

SELECT REPLACE('abcd efg','cd','XXX') FROM dual;

LENGTH()-获取字符串的长度

SELECT LENGTH('hello world') FROM dual;

SUBSTR()字符串截取

SELECT SUBSTR('abcdef',0,3) FROM dual;

字符串截取(Oracle中下标都是从1开始,如果指定为0则也会默认为1)

l 从指定位置截取到结尾

l 截取部分的字符串

截取前三位:

SELECT SUBSTR(‘abcdefg’,0,3) FROM dual;

截取后三位:

SELECT SUBSTR(‘abcdefg’,LENGTH(‘abcdefg’)-2) FROM dual;

SELECT SUBSTR(‘abcdefg’,-3) FROM dual;

ASCII()将字符转换为ASCII码

SELECT ASCII(‘A’) FROM dual;

CHR()将ASCII码转换为字符

SELECT CHR(100) FROM dual;

LTRIM()/RTRIM()/TRIM去掉左/右/所有空格

SELECT LTRIM('    AAA  ')  FROM dual;

SELECT RTRIM('    AAA  ')  FROM dual;

SELECT TRIM('    AAA  ')  FROM dual;

LPAD()/RPAD()字符串填充

SELECT LPAD('abc',10,'*') FROM dual;

SELECT RPAD('abc',10,'*') FROM dual;

SELECT RPAD(LPAD('abc',5,'*'),10,'*') FROM dual;

INSTR()字符串查找

SELECT INSTR('Hello Wold','llo') FROM dual;

CONCAT()函数 将第二个字符串附加到第一个字符串上

SELECT CONCAT('Hello',' World') FROM dual;

2 数字函数

ROUND()四舍五入函数

不保留小数:

SELECT ROUND(759.9965) FROM dual;

保留两位小数:

SELECT ROUND(759.9965,3) FROM dual;

处理整数进位:

SELECT ROUND(759.9965,-2) FROM dual;

TRUNC() 直接截取不四舍五入

SELECT TRUNC(759.9965,2) FROM dual;

SELECT TRUNC(759.9965,-2) FROM dual;

MOD() 取模(余数)函数

SELECT MOD(10,3) FROM dual;

SELECT MOD(10.5,3) FROM dual;

3 日期函数

SYSDATE:取得当前日期

修改时间格式:

ALTER SESSION SET NLS_DATE_FORMAT = ‘yyyy-mm-dd hh24:mm:ss’

日期的操作:

三天之后的日期:

SELECT SYSDATE + 3 FROM dual;

三天之前的日期:

SELECT SYSDATE -3 FROM dual;

日期操作函数:

ADD_MONTHS()

三月之后的日期:

SELECT ADD_MONTHS(SYSDATE,3) FROM dual;

三月之前的日期:

SELECT ADD_MONTHS(SYSDATE,-3) FROM dual;

MONTHS_BETWEEN()

SELECT TRUNC(MONTHS_BETWEEN(SYSDATE,TO_DATE('1987-10-18','yyyy-mm-dd'))/12) AS HIRE FROM dual;

EXTRACT()

SELECT EXTRACT(DAY FROM DATE  '2016-07-25') FROM DUAL;

LAST_DAY(x)返回包含X的月的最后一天

SELECT LAST_DAY(SYSDATE) FROM DUAL;

4 转换函数

日期格式化标志

TO_CHAR() 将日期或者数字转化为指定格式的字符串

将日期转换为字符串:

SELECT TO_CHAR(SYSDATE,'YYYY-MM-DD HH:MI:SS') FROM DUAL;

将数字转化为字符串:

SELECT

TO_CHAR(1562456845625.4512659,  '999,999,999,999,999,999.9999999') AS FORMAT_A,

TO_CHAR(1562456845625.4512659,  '000,000,000,000,000,000.0000000') AS FORMAT_B

FROM DUAL;

TO_DATE()-将字符串变为日期形式

SELECT TO_DATE('1979/09/19','YYYY/MM/DD') FROM DUAL;

TO_NUMBER()-将字符串变为数字

SELECT TO_NUMBER('23') * TO_NUMBER('55') AS RESULT FROM DUAL;

5 通用函数

NVL(x,value) 如果x为空,则返回value,否则返回x

SELECT NVL(NULL,'ABC') FROM DUAL;

SELECT NVL('HELLO','ABC') FROM DUAL;

NVL2(x,value1,value2) x非空则返回value1否则返回value2

SELECT NVL2(NULL,'ABC','DEF') FROM DUAL;

SELECT NVL2('F','ABC','DEF') FROM DUAL;

NULLIF()

SELECT NULLIF(1,1) FROM DUAL;

SELECT NULLIF(7,2) FROM DUAL;

DECODE()-类似于JAVA中的switc-case语句

找到:

SELECT DECODE(65,

60,'BAD',

65,'GOOD',

90,'EXCELLENT'

) FROM DUAL;

找不到:

SELECT DECODE(30,

60,'BAD',

65,'GOOD',

90,'EXCELLENT'

) FROM DUAL;

找不到时可以设置默认值:

SELECT DECODE(30,

60,'BAD',

65,'GOOD',

90,'EXCELLENT',

'UNKNOWN'

) FROM DUAL;

CASE-WHEN-THEN: -类似于JAVA中的switch语句

值找到:

SELECT

CASE 65

WHEN 60 THEN 'BAD'

WHEN 65 THEN 'GOOD'

WHEN 90 THEN 'EXCELLENT'

ELSE

'UNKNOWN'

END

FROM DUAL;

值找不到:

SELECT

CASE 99

WHEN 60 THEN 'BAD'

WHEN 65 THEN 'GOOD'

WHEN 90 THEN 'EXCELLENT'

ELSE

'UNKNOWN'

END

FROM DUAL;

COALESCE()- 依次判断参数是否为空,直到第一个非空值出现

SELECT COALESCE(NULL,33,NULL) FROM DUAL;

SELECT COALESCE(NULL,NULL,99) FROM DUAL;

SELECT COALESCE(NULL,NULL,NULL) FROM DUAL;

Oracle中的单行函数的更多相关文章

  1. Oracle数据库之六 单行函数

    六.单行函数 6.1.认识单行函数 ​ 函数就是和 Java 语言之中的方法的功能是一样的,都是为了完成某些特定操作的功能支持,而在 Oracle 数据库里面也包含了大量的单行函数,这些函数掌握了以后 ...

  2. Oracle中 Instr 这个函数

    http://www.jb51.net/article/42369.htm sql :charindex('字符串',字段)>0 charindex('administrator',MUserI ...

  3. 创建类似于Oracle中decode的函数

    -- 创建类似于Oracle中decode的函数create or replace function decode(variadic p_decode_list text[])returns text ...

  4. Oracle中的substr()函数 详解及应用

    注:本文来源于<Oracle中的substr()函数 详解及应用> 1)substr函数格式   (俗称:字符截取函数) 格式1: substr(string string, int a, ...

  5. MySQL之实现Oracle中的rank()函数的功能

      假设表格为student, 数据如下:   我们要在MySQL中实现Oracle中的rank()函数功能,即组内排序,具体来说: 就是对student表中按照课程(course)对学生(name) ...

  6. oracle中的trim()函数详解

    1.先看一下Oracle TRIM函数的完整语法描述 TRIM([ { { LEADING | TRAILING | BOTH }[ trim_character ]| trim_character} ...

  7. oracle中的greatest 函数和 least函数

    oracle中的greatest 函数和 least函数 原文地址:https://blog.csdn.net/sinat_32023305/article/details/78778596    g ...

  8. 问题:oracle nvl;结果:Oracle中的NVL函数

    Oracle中的NVL函数 (2012-11-30 13:21:43) 转载▼ 标签: nvl oracle 分类: Oracle Oracle中函数以前介绍的字符串处理,日期函数,数学函数,以及转换 ...

  9. Oracle中的转换函数

    Oracle中的转换函数有三个,分别为to_char(),to_date(),to_number() 1.to_char()的用法 格式化当前的日期时间 select sysdate,to_char( ...

随机推荐

  1. JSON 序列化和反序列化——JavaScriptSerializer实现

    一. JavaScriptSerializer 类由异步通信层内部使用,用于序列化和反序列化在浏览器和 Web 服务器之间传递的数据.您无法访问序列化程序的此实例.但是,此类公开了公共 API.因此, ...

  2. pam

    http://www.linux-pam.org/ sag(the linux-pam system administrators' guide)翻译(以下是网上别人的翻译,参考一下) http:// ...

  3. String的compareTo()方法返回值

    compareTo()的返回值是整型,它是先比较对应字符的大小(ASCII码顺序),如果第一个字符和参数的第一个字符不等,结束比较,返回他们之间的 差值,如果第一个字符和参数的第一个字符相等,则以第二 ...

  4. CentOS 6.6 yum 方式安装sunversion 服务器

    检查已安装版本 #检查是否安装了低版本的SVN[root@localhost /]# rpm -qa subversion #如果存储旧版本,卸载旧版本SVN[root@localhost modul ...

  5. [原]在Fedora中编译Libevent测试实例

    在我的昨天的博文<[原]我在Windows环境下的首个Libevent测试实例>中介绍了在Windows环境下如何编译一个echo server例子.今天我又试了一下在Linux环境中编译 ...

  6. [Hibernate] - Fetching strategies

    Hibernate中的抓取策略,参考文档: http://docs.jboss.org/hibernate/orm/3.5/reference/zh-CN/html/performance.html ...

  7. linux常用方法

    同步时间 ntpdate us.pool.ntp.org 查看http的并发请求数及其TCP连接状态 netstat -n | awk '/^tcp/ {++S[$NF]} END {for(a in ...

  8. android学习笔记35——AnimationDrawable资源

    AnimationDrawable资源 AnimationDrawable,代表一个动画. android既支持传统的逐帧动画(类似于电影方式,一张图片一张图片的切换),也支持通过平移.变换计算出来的 ...

  9. 就Double、Decimal来说数据计算异常

    场景: 客户提示发料时提示库存不足,可肉眼比对发料数量与库存数量没有一点问题. 但调度跟踪却发现出现“不可思议”的异常. 简单分析: 1.转Decimal再计算没问题.精度较高,存储方法也不一样,所以 ...

  10. 反转(开关问题) POJ 3276

    POJ 3276 题意:n头牛站成线,有朝前有朝后的的,然后每次可以选择大小为k的区间里的牛全部转向,会有一个最小操作m次使得它们全部面朝前方.问:求最小操作m,再此基础上求k. 题解:1.5000头 ...