数据限定与排序

6.1 简单查询语句执行顺序

from, where, group by, having, order by, select

where限定from后面的表或视图,限定的选项只能是表的列或列单行函数或列表达式,where后不可以直接使用分组函数

SQL> select empno,job from emp where sal>2000;
SQL> select empno,job from emp where length(job)>5;
SQL> select empno,job from emp where sal+comm>2000;

having限定group by的结果,限定的选项必须是group by后的聚合函数或分组列,不可以直接使用where后的限定选项。

SQL> select sum(sal) from emp group by deptno having deptno=10;
SQL> select deptno,sum(sal) from emp group by deptno having sum(sal)>9000;

如果要使用group by及having,有条件的话先使用where筛选。

6.2 排序(order by)

1)位置:order by语句总是在一个select语句的最后面。
2)排序可以使用列名,列表达式,列函数,列别名,列位置编号等都没有限制,select的投影列可不包括排序列,除指定的列位置标号外。
3)升序和降序,升序ASC(默认), 降序DESC。有空值的列的排序,缺省(ASC升序)时 null排在最后面(考点)。
4)混合排序,使用多个列进行排序,多列使用逗号隔开,可以分别在各列后面加升降序。

SQL> select ename,sal from emp order by sal;
SQL> select ename,sal as salary from emp order by salary;
SQL> select ename,sal as salary from emp order by 2;
SQL> select ename,sal,sal+100 from emp order by sal+comm;
SQL> select deptno,avg(sal) from emp group by deptno order by avg(sal) desc;
SQL> select ename,job,sal+comm from emp order by 3  nulls first;
SQL> select ename,deptno,job from emp order by deptno asc,job desc;

6.3 空值(null)

空值既不是数值0,也不是字符" ", null表示不确定。

6.3.1 空值参与运算或比较时要注意几点:

1)空值(null)的数据行将对算数表达式返回空值

SQL> select ename,sal,comm,sal+comm from emp;

ENAME             SAL       COMM   SAL+COMM
---------- ---------- ---------- ----------
SMITH             800
ALLEN            1600        300        1900
WARD             1250       500        1750
JONES            2975
MARTIN         1250       1400       2650
BLAKE            2850
CLARK            2450
SCOTT            3000
KING              5000
TURNER         1500            0       1500
ADAMS          1100
JAMES            950
FORD             3000
MILLER           1300

已选择14行。

2)分组函数忽略空值

SQL> select sum(sal),sum(sal+comm) from emp;        //为什么sal+comm的求和小于sal的求和?

SUM(SAL) SUM(SAL+COMM)
---------- -------------
     29025          7800

3)比较表达式选择有空值(null)的数据行时,表达式返回为“假”, 结果返回空行。

SQL>  select ename,sal,comm from emp where sal>=comm;

ENAME             SAL       COMM
---------- ---------- ----------
ALLEN             1600        300
WARD             1250        500
TURNER          1500          0

4)非空字段与空值字段做"||"时, null值转字符型"",合并列的数据类型为varchar2。

SQL> select ename, sal||comm from emp;

ENAME          SAL||COMM
---------- --------------------------------------------------------------------------------
SMITH          800
ALLEN          1600300
WARD           1250500
JONES          2975
MARTIN         12501400
BLAKE          2850
CLARK          2450
SCOTT          3000
KING               5000
TURNER         15000
ADAMS          1100
JAMES          950
FORD           3000
MILLER         1300

已选择14行。

5)not in 在子查询中的空值问题(见第八章)

6)外键值可以为null,唯一约束中,null值可以不唯一(见十二章)

7)空值在where子句里使用“is null”或“is not null”

SQL> select ename,mgr from emp where mgr is null;

SQL> select ename,mgr from emp where mgr is not null;

8)空值在update语句和insert语句可以直接使用“=null” 赋值

SQL> update emp set comm=null where empno=7788;

6.3.2 处理空值的几种函数方法:

1)nvl(expr1,expr2)
当第一个参数不为空时取第一个值,当第一个值为NULL时,取第二个参数的值。

SQL>select nvl(1,2) from dual;

NVL(1,2)
----------
         1

SQL> select nvl(null,2) from dual;

NVL(NULL,2)
-----------
         2

*考点:nvl函数可以作用于数值类型,字符类型,日期类型,但数据类型尽量匹配。

NVL(comm,0)
NVL(hiredate,'1970-01-01')
NVL(ename,'no manager')

2)nvl2(expr1,expr2,expr3)

当第一个参数不为NULL,取第二个参数的值,当第一个参数为NULL,取第三个数的值。

SQL> select nvl2(1,2,3) from dual;

NVL2(1,2,3)
-----------
         2

SQL> select nvl2(null,2,3) from dual;

NVL2(NULL,2,3)
--------------
            3

SQL> select ename,sal,comm,nvl2(comm,SAL+COMM,SAL) income,deptno from emp where deptno in (10,30);

ENAME                 SAL       COMM     INCOME     DEPTNO
---------- ---------- ---------- ---------- ----------
ALLEN                1600        300       1900         30
WARD                 1250        500       1750         30
MARTIN               1250       1400      2650         30
BLAKE                2850                    2850         30
CLARK                2450                     2450         10
KING                 5000                     5000         10
TURNER               1500          0         1500         30
JAMES                 950                       950         30
MILLER               1300                     1300         10

*考点: nvl和nvl2中的第二个参数不是一回事。

3)NULLIF(expr1,expr2)  /*比对两个值是否一样,一样就返回为空,否则不会为空*/
当第一个参数和第二个参数相同时,返回为空,当第一个参数和第二个数不同时,返回第一个参数值,第一个参数值不允许为null

SQL> select nullif(2,2) from dual;

NULLIF(2,2)
-----------

SQL> select nullif(1,2) from dual;

NULLIF(1,2)
-----------
          1

4)coalesce(expr1,expr2........) 返回从左起始第一个不为空的值,如果所有参数都为空,那么返回空值。

SQL> select coalesce(1,2,3,4) from dual;

COALESCE(1,2,3,4)
-----------------
                1

SQL> select coalesce(null,2,null,4) from dual;

COALESCE(NULL,2,3,4)
--------------------
                  2

oracle之数据限定与排序的更多相关文章

  1. Oracle索引梳理系列(一)- Oracle访问数据的方法

    版权声明:本文发布于http://www.cnblogs.com/yumiko/,版权由Yumiko_sunny所有,欢迎转载.转载时,请在文章明显位置注明原文链接.若在未经作者同意的情况下,将本文内 ...

  2. Oracle Where查询语句与排序语句

    SQL限制和排序数据 1.Oracle的Where条件值,字符串和日期都必须以单引号括起来. 模糊查询: like 'S%' 以S开头的任意字符 like 'S_' 以S开头的任意字符结尾的两个字符 ...

  3. sqoop工具从oracle导入数据2

    sqoop工具从oracle导入数据 sqoop工具是hadoop下连接关系型数据库和Hadoop的桥梁,支持关系型数据库和hive.hdfs,hbase之间数据的相互导入,可以使用全表导入和增量导入 ...

  4. SSIS 从oracle 转数据回MS SQL

    SSIS 从oracle 转数据回MS SQL,转每月的销售记录,大概15000以内,在开发机器上没问题,部署到生产环境出现各种状况“ SSIS 无法从连接伺服器的OLE DB提供者BULK 提取资料 ...

  5. 关于 Oracle 的数据导入导出及 Sql Loader (sqlldr) 的用法

    在 Oracle 数据库中,我们通常在不同数据库的表间记录进行复制或迁移时会用以下几种方法: 1. A 表的记录导出为一条条分号隔开的 insert 语句,然后执行插入到 B 表中2. 建立数据库间的 ...

  6. 使用JDBC处理Oracle大数据

    一.Oracle中大数据处理 在Oracle中,LOB(Large Object,大型对象)类型的字段现在用得越来越多了.因为这种类型的字段,容量大(最多能容纳4GB的数据),且一个表中可以有多个这种 ...

  7. [转]oracle 10g数据泵之impdp-同时导入多个文件

    要了解impdp,请先了解导出,我之前作过导出的笔记:oracle 10g数据泵之expdp.这两个笔记也许只对程序员有用,通常用于把正式区的数据导入到测试区,对数据库管理员也许帮助不大,他们使用这些 ...

  8. 利用jdbc处理oracle大数据---大文件和二进制文件

    一.Oracle中大数据处理 在Oracle中,LOB(Large Object,大型对象)类型的字段现在用得越来越多了.因为这种类型的字段,容量大(最多能容纳4GB的数据),且一个表中可以有多个这种 ...

  9. Oracle 删除数据后释放数据文件所占磁盘空间

    测试的时候向数据库中插入了大量的数据,测试完成后删除了测试用户以及其全部数据,但是数据文件却没有缩小.经查阅资料之后发现这是 Oracle “高水位”所致,那么怎么把这些数据文件的大小降下来呢?解决办 ...

随机推荐

  1. Spring同时集成JPA与Mybatis

    @ 目录 ORM Spring ORM Spring ORM 同时集成JPA与Mybatis 一.创建一个SpringBoot项目 二.建立用户信息登记表 三.Web应用项目集成mysql 四.添加S ...

  2. golang 标准库

    前言 不做文字搬运工,多做思路整理 就是为了能速览标准库,只整理我自己看过的...... 最好能看看英文的 标准库 fmt strconv string 跳转 golang知识库总结

  3. 一、常用的Dos命令

    # 查看目录下所有文件 dir # 切换目录 cd cd .. //返回上一级 # 清理屏幕 cls # 查询电脑ip地址 ipconfig # 退出终端 exit # 创建文件夹 md test # ...

  4. 在K3s上使用Kong网关插件,开启K3s的无限可能!

    我的工作中很重要的一部分是参加各种各样的技术会议.最近参加的是去年11月的北美KubeCon,在会议的最后一天,所有人都焦头烂额,我也一直机械地向不同的人重复我的自我介绍.后来,我已经十分烦躁,决定逃 ...

  5. 复习 Array,重学 JavaScript

    1 数组与对象 在 JavaScript 中,一个对象的键只能有两种类型:string 和 symbol.下文只考虑键为字符串的情况. 1.1 创建对象 在创建对象时,若对象的键为数字,或者由 字母+ ...

  6. 下面POM插件的作用是转换包名,修改tomcat跳转端口

    <plugin> <groupId>org.apache.tomcat.maven</groupId> <artifactId>tomcat6-mave ...

  7. python3中文输出乱码的问题

    最近使用you-get这个工具下载视频,发现命令行窗口里显示的媒体标题是乱码(但文件管理器里显示正常).我的命令行窗口的code page是936,sys.stdout.encoding是utf-8, ...

  8. python基础 Day6

    python Day6 id 可以获得python的内存地址 id的举例子 a=100 print(id(a)) #140712544153072 这里就是该对象的内存地址 is 判断的是比较内存地址 ...

  9. CentOS7 系统基于Vim8搭建Go语言开发环境

    链接:https://pdf.us/2018/11/10/2194.html 问题1:vim-go: could not find 'gopls'. Run :GoInstallBinaries to ...

  10. CRMEB小程序商城v4.0二次开发对接集成阿里云短信

    作者:廖飞 - CRMEB小程序商城研发项目组长 前言 cremb小程序商城v4.0版本支持短信平台为云信,但有部分用户有需求对接阿里云短信,这篇文章将对阿里云短信平台如何对接方以及对接流程详细说明. ...