Oracle入门第二天(下)——单行函数
一、概述
以下内容完整参阅,参考官方文档函数手册部分:https://docs.oracle.com/cd/E11882_01/nav/portal_5.htm
离线chm手册英文版:链接:https://pan.baidu.com/s/1o85jQ9G 密码:ssyj——(若无法显示正文,在文件上右键属性-解除锁定即可!)
什么是单行函数:
操作数据对象
接受参数返回一个结果
只对一行进行变换
每行返回一个结果
可以转换数据类型
可以嵌套
参数可以是一列或一个值
// 比如分组函数就是典型的多行函数
分类:
二、字符函数
大小写控制函数:
LOWER()——转化为小写
UPPER()——转化为大写
INITCAP()——首字母大写
SELECT LOWER('SQL Course'),UPPER('SQL Course'),INITCAP('SQL Course') FROM dual; LOWER('SQLCOURSE') UPPER('SQLCOURSE') INITCAP('SQLCOURSE')
------------------ ------------------ --------------------
sql course SQL COURSE Sql Course
// dual是一张虚表,并且再次提醒SQL大小写不敏感,lower()也是允许的
字符控制函数:
CONCAT('Hello', 'World')——连接字符串
SUBSTR('HelloWorld',1,5)——取子串,从下标1开始,取5个(SQL下标从1开始而不是0)
LENGTH('HelloWorld')——得到长度
INSTR('HelloWorld', 'W')——首次出现的位置
LPAD(salary,10,'*')——左补齐
RPAD(salary, 10, '*')——右补齐
TRIM('H' FROM 'HelloWorld')——去除首尾的指定字符
REPLACE(‘abcd’,’b’,’m’)——替换所有的字符,(将b替换为m)
SELECT CONCAT('HelloWorld','jiangbei'),SUBSTR('HelloWorld',1,5),LENGTH('HelloWorld'),INSTR('HelloWorld','W') FROM dual; CONCAT('HELLOWORLD','JIANGBEI' SUBSTR('HELLOWORLD',1,5) LENGTH('HELLOWORLD') INSTR('HELLOWORLD','W')
------------------------------ ------------------------ -------------------- -----------------------
HelloWorldjiangbei Hello 10 6
SELECT LPAD(salary,10,'*') FROM employees; LPAD(SALARY,10,'*')
--------------------
*****24000
*****17000
*****17000
******9000
******6000
SELECT TRIM('H' FROM 'H2H2H'),REPLACE('H2H2H2','H','M') FROM dual; TRIM('H'FROM'H2H2H') REPLACE('H2H2H2','H','M')
-------------------- -------------------------
2H2 M2M2M2
三、数字函数
ROUND(45.926,2)——四舍五入
TRUNC(45.926,2)——截断
MOD(100,3)——求余
SELECT ROUND(45.926,2),TRUNC(45.926,2),MOD(100,3) FROM dual; ROUND(45.926,2) TRUNC(45.926,2) MOD(100,3)
--------------- --------------- ----------
45.93 45.92 1
四、日期函数
SYSDATE——返回日期与时间
select sysdate from dual;
使用trunc(sysdate) 只取日期部分
日期数字运算:
在日期上加上或减去一个数字结果仍为日期。 两个日期相减返回日期之间相差的天数。
日期不允许做加法运算,无意义 可以用数字除24来向日期中加上或减去天数。
日期函数
ADD_MONTHS ('11-JAN-94',6)——'11-JUL-94'
五、转换函数
隐式转换
显示转换函数
TO_CHAR(date, 'format_model')——日期转化为字符型
日期格式如下;yyyy 年 mm 月 dd 日 day 星期 hh 小时 mi 分钟 ss 秒
TO_DATE('char','format_mldel')——字符转化为日期
TO_CHAR(number, 'format_model')——数字转字符
SELECT TO_CHAR(1234567.89,'999,999,999.99')
TO_NUMBER(‘¥1,234,567,890.00’,’L999,999,999,999.99’)
六、通用函数
这些函数适用于任何数据类型,同时也适用于空值:
NVL (expr1, expr2)——空值转化为指定值
NVL2 (expr1, expr2, expr3)——expr1不为NULL,返回expr2;为NULL,返回expr3。
NULLIF (expr1, expr2)——相等返回NULL,不等返回expr1
COALESCE (expr1, expr2, ..., exprn)——交替判断是否为空:若expr1为空,返回expr2;若expr2为空,返回expr3;依次类推
七、条件表达式
SQL中使用IF/ELSE可以有两种方式:
CASE表达式;
语法:
CASE expr WHEN comparison_expr1 THEN return_expr1
[WHEN comparison_expr2 THEN return_expr2
WHEN comparison_exprn THEN return_exprn
ELSE else_expr]
END
示例:
SELECT
employee_id,last_name,department_id,CASE department_id WHEN 10 THEN salary*1.1
WHEN 20 THEN salary*1.2
ELSE salary*1.3
END AS NEW_SAL
FROM
employees
WHERE
department_id IN (10,20,30)
// 如果后面不使用别名,将会生成内置别名
EMPLOYEE_ID LAST_NAME DEPARTMENT_ID NEW_SAL
----------- ------------------------- ------------- ----------
114 Raphaely 30 14300
115 Khoo 30 4030
116 Baida 30 3770
117 Tobias 30 3640
118 Himuro 30 3380
119 Colmenares 30 3250
200 Whalen 10 4840
201 Hartstein 20 15600
202 Fay 20 7200 9 rows selected
更多CASE用法,参考:http://blog.itpub.net/27042095/viewspace-739106/
DECODE函数;
语法:
DECODE(col|expression, search1, result1 ,
[, search2, result2,...,]
[, default])
decode(条件,值1,返回值1,值2,返回值2,...值n,返回值n,缺省值)
示例:
SELECT last_name, job_id, salary,
DECODE(job_id, 'IT_PROG', 1.10*salary,
'ST_CLERK', 1.15*salary,
'SA_REP', 1.20*salary,
salary)
REVISED_SALARY
FROM employees;
Oracle入门第二天(下)——单行函数的更多相关文章
- Oracle笔记(三)单行函数
-函数 函数像一个黑盒子一样(看不到里边的构造),有参数返回值,可以为我们完成一定的功能. -单行 这种函数会对结果中的每一行计算一次,每行返回一个结果,单行概念区别于分组函数. 单行函数主要分为以下 ...
- Oracle入门第二天(上)——基本查询SQL
一.SQL概述 起源于标准不再赘述,主要分为DDL,DML,DCL 相关介绍,参考MySQL章节:http://www.cnblogs.com/jiangbei/p/6696202.html 二.基本 ...
- Oracle笔记(五) 单行函数
虽然各个数据库都是支持SQL语句的,但是每一个数据库也有每一个数据库自己所支持的操作函数,这些就是单行函数,而如果要想进行数据库开发的话,除了要会使用SQL之外 ,就是要多学习函数. 单行函数主要分为 ...
- Oracle SQL Lesson (3) - 使用单行函数自定义输出
大小写转换函数LOWER('SQL Course') = sql courseUPPER('SQL Course') = SQL COURSEINITCAP('SQL Course') = Sql C ...
- Shell编程入门(第二版)(下)
... ... command n done #select把关键字中的每一项做成类似表单,以交互的方式执行do和done之间的命令 示例-select.sh [python] view plainc ...
- Oracle入门第六天(下)——高级子查询
一.概述 主要内容: 二.子查询介绍 1.简单子查询(WHERE子查询) SELECT last_name FROM employees WHERE salary > (SELECT salar ...
- Oracle数据库从入门到精通 单行函数问题
视频课程:李兴华 Oracle从入门到精通视频课程 学习者:阳光罗诺 视频来源:51CTO学院 Oracle数据库从入门到精通-单行函数 在数据库中,为了方便用户的数据开发,往往会提供一系列的支持函数 ...
- Oracle 单行函数
一.什么是函数 任何东西,只要它能接收输入,对输入进行加工并产生输出,它就可以被称为函数. 二.单行函数简介 单行函数只对表中的一行数据进行操作,并且对每一行数据只产生一个输出结果.单行函数可以接受一 ...
- Oracle Day2 过滤、排序、单行函数
1.过滤和排序 SQL> --查询10号部门的所有员工信息 SQL> select * from emp ; 未选定行 SQL> ed SP2: 无法创建保存文件 "afi ...
随机推荐
- [BZOJ 4573][ZJOI 2016]大森林
[LOJ 2092][BZOJ 4573][UOJ 195][ZJOI 2016]大森林 题意 给定一个树序列, 初始时所有树都只有一个点, 要求支持三种操作: 区间种树(在某个特定点上长出一个子结点 ...
- Linux命令--系统管理
shutdown命令 Linux shutdown命令可以用来进行关机程序,并且在关机以前传送讯息给所有使用者正在执行的程序,shutdown 也可以用来重开机. 使用权限:系统管理者. 语法 shu ...
- 自定义控件(视图)2期笔记12:View的滑动冲突之 外部拦截法
1. 外部拦截法: 点击事件通过父容器拦截处理,如果父容器需要就拦截,不需要就不拦截. 这种方法比较符合事件分发机制.外部拦截法需要重写父容器的onInterceptTouchEvent方法,在内部做 ...
- linux mint gcc 编译第一个c程序
GCC是Linux操作系统下一个非常重要的源代码编译工具,有着许多重要的选项,支持许多不同语言的编译,如C.C++.Ada. Fortran.Objective.Perl.Python.Ruby以及J ...
- 2016424王启元 Exp6信息搜集与漏洞扫描
一.原理与实践说明 1.实践内容 本实践的目标是掌握信息搜集的最基础技能.具体有: 1.各种搜索技巧的应用 2.DNS IP注册信息的查询 3.基本的扫描技术:主机发现.端口扫描.OS及服务版本探测. ...
- Java反序列化之Jackson-databind
这个洞的cve编号:CVE-2017-17485,漏洞环境就如第一个链接那样,jdk需要在jdk 1.8以上. 先看一下Jackson-databind的用法,说白了就是将json转换成对象. tes ...
- Linux学习总结(十七)-shell 基础知识
一 先介绍几种常用字符: 1 * 匹配任意个任意字符2 ?匹配一个任意字符3 # 注释符号,符号后的语句不被执行4 \脱意字符,后面跟带含义字符时,照原字符输出5 []匹配包含在[]之中的任意一个字符 ...
- 智慧监狱来了!SaCa EMM 助推现代监狱建设迈上新台阶
近几年来,移动化已经成为警务信息化建设的必然方向,为紧急和突发事件的处理提供了信息依据.为监狱民警提供移动警务所需的信息管理系统,司法系统从很早就开始推动警务通项目.为了落实移动警务的工作需求,很多监 ...
- 关于RFID电动车防盗、校园答题卡(超低功耗2.4G芯片SI24R2E)
Si24R2E 是一颗工作在2.4GHz ISM 频段,专为低功耗有源RFID 应用场合设计,集成嵌入式发射基带的无线发射芯片.128 次可编程NVM 存储器以及自动发射模块.工作频率范围 ...
- SQLIO 磁盘測试工具參考
SQLIO 下载地址:id=20163">SQLIO Disk Subsystem Benchmark Tool 默认文件夹:C:\Program Files\SQLIO 以命令行执行 ...