Oracle学习笔记之四,SQL语言入门中摘出来的,独立成一章节

3.1 字符类函数

  1. ASCII(c)和CHR(i)    分别用于返回一个字符的ASCII码和返回给定ASCII值所对应的字符。
  2. CONCAT(s1,s2)    将字符串s2连接到字符串s1的后面。任一字符串为空值则忽略此空值;两值都为空值则返回null。同样“||"也有此功能,且更方便些。
  3. INITCAP(s)    将字符串s的每个单词的第一个字母大写,其它字母小写。
  4. INSTR(s1,s2[,i][,j])    该函数用于返回字符串s2在s1中第j次出现时的位置,从i位开始搜索。如果i为负数,则搜索从右到左进行。
  5. LENGTH(s)    返回字符串s的长度。注意:一个汉字的长度是1。
  6. LOWER(s)和UPPER(s)    返回字符串s的小写与大写形式。
  7. LTRIM(s1,s2)、RTRIM(s1,s2)   分别移去字符串开始、结尾部分指定字符。默认空格。
  8. TRIM( [ leading | trailing | both  [ trim_character ]  ]   string1 )     该函数移去字符串开始与结尾部分指定字符。也可以只移去开始或者是结尾部分指定字符。
  9. REPLACE(s1,s2[,s3])    该函数使用s3字符串替换出现在s1字符串中的所有s2字符串,返回替换后的新字符串。s3默认值为空字符串。
  10. SUBSTR(s,i,[j])   从字符串s1的第i个位置截取长度为j的子字符串。省略j则取到尾部。
select ASCII('A'),CHR(65) from dual;
--65 A
select CONCAT('Hello ','World'),'Hello '||'World' from dual;
--Hello World Hello World
select INITCAP('I am a good boy!') from dual;
--I Am A Good Boy!
select INSTR('Hello World...','World',1,1),INSTR('Hello World...','World',-1,1) from dual;
--7 7
select LENGTH('Hello') from dual;
--
select LOWER('Hello'),UPPER('Hello') from dual;
--hello HELLO
select LTRIM('###Hello##','#'),RTRIM('###Hello##','#') from dual;
--Hello## ###Hello
select TRIM(' tech '),TRIM(' ' from ' tech '),TRIM(leading '' from ''),TRIM(trailing '' from 'Tech1'),TRIM(both '' from '123Tech111') from dual;
--tech tech 123 Tech 23Tech
select REPLACE('Hello World','World','Beijing'),REPLACE('Hello World','World') from dual;
--Hello Beijing Hello
select SUBSTR('Hello World',1,5),SUBSTR('Hello World',6) from dual;
--Hello World

3.2 数字类函数

  1. CEIL(n)         返回大于或等于数值n的最小整数。
  2. ROUND(n1,n2)  返回舍入小数点右边n2位的n1的值,n2默认值为0。如果n2为负数,就舍入到小数点左边的相应的位上。
  3. POWER(n1,n2)  返回n1的n2次方。
  4. MOD(n1,n2)      返回n1除以n2的余数。
  5. ABS(n)             返回n的绝对值。
  6. FLOOR(n)         返回小于或等于n的最小整数。
select CEIL(7.3) from dual;
--
select ROUND(123.4567,2),ROUND(123.4567),ROUND(123.4567,-2) from dual;
--123.46 123 100
select POWER(2,3) from dual;
--
select MOD(10,3) from dual;
--
select ABS(-10) from dual;
--
select FLOOR(7.3) from dual;
--

3.3 日期和时间类函数

  1. SYSDATE()                返回系统当前日期。
  2. MONTHS_BETWEEN(d1,d2)    返回d1和d2之间的数目,若d1与d2的日期(DAY)都相同,或者都是该月的最后一天,则返回一个整数,否则返回的结果将包含一个小数。
  3. LAST_DAY(d)             返回包含日期d月份的最后一天。
  4. NEXT_DAY(d,day)      返回d后第一周指定day的日期。
  5. ADD_MONTHS(d,i)     返回日期d加上i个月之后的结果,i为任意整数。
select SYSDATE from dual;
--2013/7/27 星期六 20:59:34
select MONTHS_BETWEEN(TO_DATE('2013-7-27','yyyy-mm-dd'),TO_DATE('2013-12-7','yyyy-mm-dd')) from dual;
---4.35483870967741935483870967741935483871
select LAST_DAY(TO_DATE('2013-7-27','yyyy-mm-dd')) from dual;
--2013/7/31 星期三
select NEXT_DAY(TO_DATE('2013-7-27','yyyy-mm-dd'),'星期二') from dual;
--2013/7/30 星期二
select ADD_MONTHS(TO_DATE('2013-7-27','yyyy-mm-dd'),2) from dual;
--2013/9/27 星期五

3.4 转换类函数

  1. TO_CHAR(x[,format])     该函数实现将表达式转换为字符串。

    参考:http://www.java2s.com/Tutorial/Oracle/0300__Conversion-Functions/0140__TO_CHAR.htm

  2. TO_DATE(s[,format])     该函数实现将字符串s转换为日期类型。
  3. TO_NUMBER(s[,format])     该函数返回字符串s代表的数字。

    参考:http://www.java2s.com/Tutorial/Oracle/0300__Conversion-Functions/0160__TO_NUMBER.htm

select TO_CHAR(sysdate,'yyyy-mm-dd hh24:mi:ss'),TO_CHAR(12345.67, '$99,999.99') from dual;
--2013-07-27 21:00:12 $12,345.67
select TO_DATE('2013-7-27 12:43:32','yyyy-mm-dd hh24:mi:ss') from dual;
--2013/7/27 星期六 12:43:32
select TO_NUMBER('98.32'),TO_NUMBER('$98.32','$999.99'),TO_NUMBER('1E+6','9.99EEEE') from dual;
--98.32 98.32 1000000

3.5  聚合类函数

  1. AVG(x[DISTINCT|ALL])          计算选择列表项的平均值。
  2. COUNT(x[DISTINCT|ALL])      返回查询结果中的记录数。
  3. MAX(x[DISTINCT|ALL])          返回选择列表项目中的最大数。
  4. MIN(x[DISTINCT|ALL])          返回选择列表项目中的最小数。
  5. SUM(x[DISTINCT|ALL])          返回选择列表项目的数值总和。
select AVG(BROWSE_COUNT) from BBSDETAIL;
--2378.136894183198040251693164897449445218
select MAX(BROWSE_COUNT) from BBSDETAIL;
--
select MIN(BROWSE_COUNT) from BBSDETAIL;
--
select SUM(BROWSE_COUNT) from BBSDETAIL;
--

3.6 其它辅助函数

  1. DECODE(exp,s1,r1,s2,r2..s,r[,default])     在一个函数内实现if else的功能。exp为输入值,s做为对比值,相同则返回r,如果s有多个,则持续遍历所有s,直到某个条件为真为止;匹配不成功时返回默认值default,如果没有默认值,则返回空。
  2. GREATEST(n1,n2,...n)     返回序列中的最大值。
  3. LEAST(n1,n2....n)           返回序列中的最小值。
  4. NULLIF(c1,c2)                逻辑等价于:case when c1 = c2 then null else c1 end。
  5. NVL(c1,c2)                     逻辑等价于:if c1 is null then c2 else c1 end。
select DECODE('CM','AM','RE1','BM','RE2','CM','RE3','UNKNOWN') from dual;
--RE3
select GREATEST(12,34,55,1,23,12) from dual;
--
select LEAST(12,34,55,1,23,12) from dual;
--
select NULLIF('Hello','World'),NULLIF('Hello','Hello') from dual;
--Hello
select NVL('Hello','World'),NVL(null,'World') from dual;
--Hello World

Oracle学习笔记之四sp1,Oracle 11g的常用函数的更多相关文章

  1. Oracle学习笔记之四,SQL语言入门

    1. SQL语言概述 1.1 SQL语言特点 集合性,SQL可以的高层的数据结构上进行工作,工作时不是单条地处理记录,而对数据进行成组的处理. 统一性,操作任务主要包括:查询数据:插入.修改和删除数据 ...

  2. Oracle学习笔记二 初识Oracle(二)

    Windows 中的 Oracle 服务 Oracle 9i的每个实例在Windows中都作为一项服务启动 服务是在 Windows 注册表中注册的可执行进程,由 Windows 操作系统管理 “服务 ...

  3. Oracle学习笔记之五,Oracle 11g的PL/SQL入门

    1. PL/SQL概述 PL/SQL(Procedural Language/SQL)是Oracle的专用语言,是对标准SQL语言的扩展,它允许在其内部嵌套普通的SQL语句,还可以定义变量和常量,允许 ...

  4. Oracle学习笔记之五sp1,PL/SQL之BULK COLLECT

    Bulk Collect特性可以让我们在PL/SQL中能使用批查询,批查询在某些情况下能显著提高查询效率. BULK COLLECT 子句会批量检索结果,即一次性将结果集绑定到一个集合变量中,并从SQ ...

  5. Oracle学习笔记之三,Oracle 11g数据库的启动与关闭

    SQL*PLus命令 SQLPLUS username[/password][@connect_identifier][AS SYSOPER|SYSDAB] 1. 启动数据库实例 STARTUP [n ...

  6. 【Oracle学习笔记-2】Oracle基础术语解析

    来自为知笔记(Wiz) 附件列表 Oracle概念解析.png 表空间.png 大小关系.png 段segment.png 块block.png 区entent.png 数据库基本概念.png

  7. Oracle学习笔记一 初识Oracle

    数据库简介 数据库(Database)是按照数据结构来组织.存储和管理数据的仓库.SQL 是 Structured Query Language(结构化查询语言)的首字母缩写词. 定义 数据库,简单来 ...

  8. Oracle 学习笔记2:几个入门常用命令

    oracle提供的交互方式有两种:sqlplus(命令行) sqlplusw(图形界面) 进入sqlplus方式:cmd中输入sqlplus 进入sqlplusw方式:cmd中输入sqlplusw 更 ...

  9. 【oracle学习笔记02】Oracle Architecture —— Process Structure

    Oracle中有三类进程: 1 User Process 2 Server Process Server Process is a program that directly interacts wi ...

随机推荐

  1. sqlite可视化工具推荐

    软件名称:SQLite Expert 下载地址:http://www.sqliteexpert.com/download.html 下载免费的Personal版本就可以了 我试用了SQLite Exp ...

  2. 【java读书笔记】JSTL,高速精通

    JSTL并非什么新颖的技术并且非常easy,甚至有人觉得JSTL已经过时了.可是我觉得它既然存在,就有存在的道理.作为技术人员就应该知道它们是什么,怎么使用,有什么长处. JSTL包括两部分:标签库和 ...

  3. sass / scss

    Sass 有两种语法规则(syntaxes),目前新的语法规则(从 Sass 3开始)被称为 “SCSS”( 时髦的css(Sassy CSS)),它是css3语法的的拓展级,就是说每一个语法正确的C ...

  4. Servlet介绍(一)

    Servlet介绍(一) Servlet是一个执行在webserver上的小的Java程序,它通过接收和响应webclient的请求.在tomcatserver中有已经帮我们实现好了Servlet接口 ...

  5. 自己写的一个读取execl的帮助类

    目标:读取execl的第一个sheet,并传入不需要读取的表头的行数,返回该execl里所有数据的list 解析共有2种:1.DOM      2.SAX import java.io.File; i ...

  6. doGet和doPost区别

    1,form运行方式 当form框里面的method为get时,执行doGet方法当form框里面的method为post时,执行doPost方法 2,生成方式 get方式有四种:1)直接在URL地址 ...

  7. CAS 5.1.x 的搭建和使用(三)—— 通过官方示例来熟悉客户端搭建

    CAS单点登录系列: CAS 5.1.x 的搭建和使用(一)—— 通过Overlay搭建服务端 CAS5.1.x 的搭建和使用(二)—— 通过Overlay搭建服务端-其它配置说明 CAS5.1.x ...

  8. Linux应用小技巧

    简介 本文针对Linux操作过程中提升工作效率问题,给出常见操作技巧,主要从Linux终端管理.显示git分支.终端快速检索历史命令等方面进行介绍. 本文内容主要以Ubuntu系统为例进行介绍. Li ...

  9. Linux安装Nginx1.7.4、php5.5.15和配置

    Nginx是一个轻量级的高性能Webserver.反向代理server.邮件(IMAP/POP3/SMTP)server,是Igor Sysoev为俄罗斯訪问量第二的Rambler.ru网站开发,第一 ...

  10. Spring MVC request flow

    1. When we enter a URL in the browser, the request comes to the dispatcher servlet.The dispatcher se ...