通用函数(学习笔记)

--***************通用函数
--NVL处理NULL
--NVL(数字|列,默认值),如果显示数字是NULL的话,则使用默认值
--NVL2(数字|列,默认值1,默认值2) 如果列不是NULL则返回结果1,如果为空返回2
--NULLIF(表达式1,表达2)比较表达式1,和表达2,的结果是否相等,如果相等返回NULL,如果不相等返回表达式1
--DECODE(列|值,判断值1,显示结果1,判断值2,显示结果2.............)
--CASE 列|数值 WHEN 表达式1 THEN 显示结果1,else表达式n..end
--COALESCE (表达1,表达2,。。。。表达n)
--使用NVL处理NULL
--要求查询员工的编号,姓名,职位,入职日期和年薪(月薪+comm)*12
--验证NVL
SELECT NVL(NULL,0),NVL(3,0) FROM dual;

SELECT e.empno,e.ename,e.job,e.hiredate,
(e.sal+NVL(e.comm,0))*12 年薪
FROM emp e;

--使用NVL2函数
SELECT e.empno,e.ename,e.job,e.hiredate,
(e.sal+NVL2(e.comm,comm,0))*12 年薪
from emp e;

SELECT e.empno,e.ename,e.job,e.hiredate,e.comm,
NVL2(e.comm,e.sal+e.comm,e.sal)*12 年薪
from emp e;

--NULLIF函数比较2个表达式,如果相等返回NULL,不相等返回表达式1
SELECT NULLIF(1,1),NULLIF(1,2) FROM dual;
--比较名字长度和职位长度
SELECT e.empno,e.ename,e.job,LENGTH(e.ename),LENGTH(e.job),
NULLIF(LENGTH(e.ename),LENGTH(e.job)) 长度是否相同
FROM emp e;
--decode使用DECODE要全部判断,如果没有判断的内容就会显示NULL
SELECT e.ename,e.sal,
DECODE(job,‘CLERK‘,‘业务员‘,
‘SALESMAN‘,‘销售员‘,
‘MANAGER‘,‘经理‘,
‘ANALYST‘,‘分析师‘,
‘PRESIDENT‘,‘总裁‘) 职位
FROM emp e;

--CASE表达式
--显示每个员工的姓名,工资,职位,同时显示新的工资(新工资为业务员增长10%,销售员增加20%,经理增长30%,其他职位的人增长50%
SELECT e.ename,e.sal,e.job,
CASE e.job WHEN ‘CLERK‘ THEN e.sal*1.1
WHEN ‘SALESMAN‘ THEN e.sal*1.2
WHEN ‘SALSEMAN‘ THEN e.sal*1.3
ELSE e.sal*1.5
END 新工资
FROM emp e;

---coalesce (表达1,表达2,。。。。表达n)依次判断,如果表达式1为NULL,则显示表达式2,如果表达式2是NULL,则显示表达式3.。。。。。
SELECT e.ename,e.sal,e.comm,
COALESCE(e.comm,100,2000),COALESCE(e.comm,NULL,NULL)
FROM emp e;

时间: 2024-08-29 11:09:54

通用函数(学习笔记)的相关文章

OpenCV之Python学习笔记

OpenCV之Python学习笔记 直都在用Python+OpenCV做一些算法的原型.本来想留下发布一些文章的,可是整理一下就有点无奈了,都是写零散不成系统的小片段.现在看 到一本国外的新书<OpenCV Computer Vision with Python>,于是就看一遍,顺便把自己掌握的东西整合一下,写成学习笔记了.更需要的朋友参考. 阅读须知: 本文不是纯粹的译文,只是比较贴近原文的笔记:         请设法购买到出版社出版的书,支持正版. 从书名就能看出来本书是介绍在Pytho

python学习笔记大纲

因为工作需要,开始了python的学习之旅.学习的主要内容包括python基础知识.python数据分析基础知识.numpy专题学习.基于python的机器学习算法实现. 下面是系列笔记的一个大纲,希望朋友们多提意见和建议. [一]python基础知识 python基础教程学习笔记---(1)基础语法 python基础教程学习笔记---(2)列表和元组 python基础教程学习笔记---(3)字符串 python基础教程学习笔记---(4)字典 python基础教程学习笔记---(5)条件.循环

R语言学习笔记

參考:W.N. Venables, D.M. Smith and the R DCT: Introduction to R -- Notes on R: A Programming Environment for Data Analysis and Graphics,2003. http://bayes.math.montana.edu/Rweb/Rnotes/R.html 前言:关于R 在R的官方教程里是这么给R下注解的:一个数据分析和图形显示的程序设计环境(A system for data

vector 学习笔记

vector 使用练习: /**************************************** * File Name: vector.cpp * Author: sky0917 * Created Time: 2014年04月27日 11:07:33 ****************************************/ #include <iostream> #include <vector> using namespace std; int main

Caliburn.Micro学习笔记(一)----引导类和命名匹配规则

Caliburn.Micro学习笔记(一)----引导类和命名匹配规则 用了几天时间看了一下开源框架Caliburn.Micro 这是他源码的地址http://caliburnmicro.codeplex.com/ 文档也写的很详细,自己在看它的文档和代码时写了一些demo和笔记,还有它实现的原理记录一下 学习Caliburn.Micro要有MEF和MVVM的基础 先说一下他的命名规则和引导类 以后我会把Caliburn.Micro的 Actions IResult,IHandle ICondu

jQuery学习笔记(一):入门

jQuery学习笔记(一):入门 一.JQuery是什么 JQuery是什么?始终是萦绕在我心中的一个问题: 借鉴网上同学们的总结,可以从以下几个方面观察. 不使用JQuery时获取DOM文本的操作如下: 1 document.getElementById('info').value = 'Hello World!'; 使用JQuery时获取DOM文本操作如下: 1 $('#info').val('Hello World!'); 嗯,可以看出,使用JQuery的优势之一是可以使代码更加简练,使开

[原创]java WEB学习笔记93:Hibernate学习之路---Hibernate 缓存介绍,缓存级别,使用二级缓存的情况,二级缓存的架构集合缓存,二级缓存的并发策略,实现步骤,集合缓存,查询缓存,时间戳缓存

本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱好者,互联网技术发烧友 微博:伊直都在0221 QQ:951226918 -----------------------------------------------------------------------------------------------------------------

Activiti 学习笔记记录(三)

上一篇:Activiti 学习笔记记录(二) 导读:上一篇学习了bpmn 画图的常用图形标记.那如何用它们组成一个可用文件呢? 我们知道 bpmn 其实是一个xml 文件

HTML&CSS基础学习笔记8-预格式文本

<pre>标签的主要作用是预格式化文本.被包围在 pre 标签中的文本通常会保留空格和换行符.而文本也会呈现为等宽字体. <pre>标签的一个常见应用就是用来表示计算机的源代码.当然你也可以在你需要在网页中预显示格式时使用它. 会使你的文本换行的标签(例如<h>.<p>)绝不能包含在 <pre> 所定义的块里.尽管有些浏览器会把段落结束标签解释为简单地换行,但是这种行为在所有浏览器上并不都是一样的. 更多学习内容,就在码芽网http://www.

java/android 设计模式学习笔记(14)---外观模式

这篇博客来介绍外观模式(Facade Pattern),外观模式也称为门面模式,它在开发过程中运用频率非常高,尤其是第三方 SDK 基本很大概率都会使用外观模式.通过一个外观类使得整个子系统只有一个统一的高层的接口,这样能够降低用户的使用成本,也对用户屏蔽了很多实现细节.当然,在我们的开发过程中,外观模式也是我们封装 API 的常用手段,例如网络模块.ImageLoader 模块等.其实我们在开发过程中可能已经使用过很多次外观模式,只是没有从理论层面去了解它. 转载请注明出处:http://bl