一、概述

  1.什么是视图(VIEW)

    视图 从表中抽出的逻辑上相关的数据集合(是一张虚表)。

  2.为什么使用视图

    1.控制访问

    2.简化查询

  3.视图的分类

    

二、视图管理

  1.创建视图

CREATE [OR REPLACE] [FORCE|NOFORCE] VIEW view
[(alias[, alias]...)]
AS subquery
[WITH CHECK OPTION [CONSTRAINT constraint]]
[WITH READ ONLY [CONSTRAINT constraint]];

  示例:

  

  这里出现个小插曲,我们根据之前的管理控制台的学习,给当前用户SCOTT添加创建VIEW的权限!

  以DBA的权限进入:(无需输入用户名密码)

  

  进入之后按照之前的操作流程增加权限——应用即可!

  可以通过子查询的列别名给视图指定列名!

  2.修改视图

  通过增加 OR REPLACE进行修改(实际上是替换了)

CREATE OR REPLACE VIEW empvu80
(id_number, name, sal, department_id)
AS SELECT employee_id, first_name || ' ' || last_name,
salary, department_id
FROM employees
WHERE department_id = 80;

  其他诸如设置视图只读等,可以通过视图创建处的语法进行操作!

  3.视图限制

  

  

  

  当然,以上都可以通过 WITH READ ONLY进行只读限制,限制DML操作

  4.删除视图

DROP VIEW viewname

三、TOP-N分析

  1.什么是TOP-N(基本上有些类似MySQL的limit了)

    Top-N 分析查询一个列中最大或最小的 n 个值:

    最大和最小的值的集合是 Top-N 分析所关心的

  2.语法

SELECT [column_list], ROWNUM
FROM (SELECT [column_list]
FROM table
ORDER BY Top-N_column)
WHERE ROWNUM <= N;

  注意: 对 ROWNUM(称之为伪列) 只能使用 < 或 <=, 而用 =, >, >= 都将不能返回任何数据。

  示例

  直接按照伪列(返回结果的行号,就是这个伪列了!)进行排序得到如下结果(注意WHERE 和 ORDER BY的顺序):

SELECT rownum,employee_id,last_name,salary
FROM employees
WHERE ROWNUM <= 10
ORDER BY salary DESC ROWNUM EMPLOYEE_ID LAST_NAME SALARY
---------- ----------- ------------------------- ----------
1 100 King 24000.00
2 101 Kochhar 17000.00
3 102 De Haan 17000.00
9 108 Greenberg 12000.00
4 103 Hunold 9000.00
10 109 Faviet 9000.00
5 104 Ernst 6000.00
6 105 Austin 4800.00
7 106 Pataballa 4800.00
8 107 Lorentz 4200.00 10 rows selected

  发现这个ROWNUM默认是按照employee_id来进行排序的!也就是把employee_id的前10个id进行了输出!

  我们进行修改,把排序好的表作为一个子表:

SELECT rownum,employee_id,last_name,salary
FROM(
SELECT employee_id,last_name,salary
FROM employees
ORDER BY salary DESC)
WHERE ROWNUM <= 10 ROWNUM EMPLOYEE_ID LAST_NAME SALARY
---------- ----------- ------------------------- ----------
1 100 King 24000.00
2 101 Kochhar 17000.00
3 102 De Haan 17000.00
4 145 Russell 14000.00
5 146 Partners 13500.00
6 201 Hartstein 13000.00
7 108 Greenberg 12000.00
8 147 Errazuriz 12000.00
9 205 Higgins 12000.00
10 168 Ozer 11500.00 10 rows selected

  更多的一个应用是用于分页上:  

SELECT *
FROM(
SELECT ROWNUM RN,A.*
FROM(
SELECT employee_id,last_name,salary
FROM employees
ORDER BY salary DESC) A ) B
WHERE B.RN >= 20 AND B.RN <=30

  这样,借助一个别名RN就摆脱了ROWNUM写法的控制,当然,也有另外一种写法:

SELECT *
FROM (SELECT ROWNUM RN, A.*
FROM (SELECT * FROM BPM_PROCVAR ORDER BY VARID) A
WHERE ROWNUM <= 40) B
WHERE B.RN >= 21;

  关于两种分页写法的详细探讨,参考https://www.cnblogs.com/ileaves/p/6393762.html

Oracle入门第五天(上)——数据库对象之视图的更多相关文章

  1. java入门第五步之数据库项目实战【转】

    在真正进入代码编写前些进行一些工具的准备: 1.保证有一个可用的数据库,这里我用sql server 2000为例,2.拥有一个ide,如ecelise或myeclipse等,这里我使用的是myecl ...

  2. Oracle入门第五天(下)——数据库其他对象

    一.概述 其他数据库对象 主要掌握的为序列 二.序列 1.什么是序列 序列: 可供多个用户用来产生唯一数值的数据库对象 自动提供唯一的数值 共享对象 主要用于提供主键值 将序列值装入内存可以提高访问效 ...

  3. Oracle入门第四天(上)——表管理与数据处理

    一.常见数据库对象 1.基本对象 对应的对象英文名参考:https://docs.oracle.com/cd/B19306_01/server.102/b14220/intro.htm#sthref6 ...

  4. DBArtist之Oracle入门第4步: Oracle创建数据库

    刚开始进去后,我是懵逼的状态,不知道要干嘛,之前常用的是MSSQL,感觉两者还是有区别的: oracle中:1.查询数据库名:select name,dbid from v$database;或者sh ...

  5. JavaMail入门第五篇 解析邮件

    上一篇JavaMail入门第四篇 接收邮件中,控制台打印出的内容,我们无法阅读,其实,让我们自己来解析一封复杂的邮件是很不容易的,邮件里面格式.规范复杂得很.不过,我们所用的浏览器内置了解析各种数据类 ...

  6. oracle学习笔记(十四) 数据库对象 索引 视图 序列 同义词

    数据库对象 用户模式:指数据库用户所创建和存储数据对象的统称.在访问其它用户模式的数据库对象时需加上用户模式. 如:scott.emp, scott.dept等. 数据库对象包括:表.视图.索引.序列 ...

  7. oracle学习笔记(十四) 数据库对象 索引 视图 序列 同义词

    数据库对象 用户模式:指数据库用户所创建和存储数据对象的统称.在访问其它用户模式的数据库对象时需加上用户模式. 如:scott.emp, scott.dept等. 数据库对象包括:表.视图.索引.序列 ...

  8. Oracle数据库对象_视图

    视图是一种非常重要的数据库对象,它的形式类似于普通表,我们可以从视图中查询数据. 实际上它是建立在表上的一种虚表,在视图中并不存储真正的数据,而是仅仅保存一条SELECT语句,对视图的访问将被转化为对 ...

  9. 关于ORACLE通过file_id与block_id定位数据库对象遇到的问题的一点思考

    在ORACLE中,我们可以通过file_id(file#)与block_id(block#)去定位一个数据库对象(object).例如,我们在10046生成的trace文件中file#=4 block ...

随机推荐

  1. 乘风破浪:LeetCode真题_006_ZigZag Conversion

    乘风破浪:LeetCode真题_006_ZigZag Conversion 一.前言 到这里我们对基本的问题有了一定的理解,其中字符串的操作一直是一个比较困难的问题,这一点我们需要认真对待,采用合理的 ...

  2. git操作:

    error: Your local changes to the following files would be overwritten by merge: **/**/**.php Please, ...

  3. Programming Assignment 3: Baseball Elimination

    编程作业三 作业链接:Baseball Elimination & Checklist 我的代码:BaseballElimination.java 问题简介 这是一个最大流模型的实际应用问题: ...

  4. Java面试基本知识

    Java基本知识 基本知识 服务器:Tomcat 支持Servlet jsp JBoss 开源应用服务器 Apache:最广泛的http服务器,只支持静态网页 String是长度不可变,用+=的时候会 ...

  5. ssh整合之Session延迟加载问题的解决

    问题描述:在使用Hibernate和Struts是经常会遇到如下BUG: org.apache.struts2.json.JSONException: org.apache.struts2.json. ...

  6. css3 网格背景

    background-image: -webkit-gradient(linear, 0 0, 100% 100%, color-stop(.25, rgba(255, 255, 255, .2)), ...

  7. 四级菜单实现(Python)

    menu_dict = { '山东' : { '青岛' : { '四方':{'兴隆路','平安路','杭州路'}, '黄岛':{}, '崂山':{} }, '济南' : { '历城':{}, '槐荫' ...

  8. 用Qt制作的Android独立游戏《吃药了》公布

           一个多月的努力最终有了回报,我自己研究制作的独立游戏<吃药了>.最终在360应用商店上线了.        这一款游戏呢.使用的是Qt开发的.事实上开发这款简单的应用之前.我 ...

  9. 【[IOI2005]Riv 河流】

    趁魏佬去英语演讲了,赶快%%%%%%%%%%%%%%魏佬 基本上是照着魏佬的代码写的 这其实还是一个树上背包 我们用\(dp[i][j][k]\)表示在以\(i\)为根的子树里,我们修建\(k\)个伐 ...

  10. 2、Android-UI(常用控件)

    2.1.如何编写程序页面 Android中有许多编写程序的方式可供选择 Android Studio和Eclipse中都提供了响应的可视化编辑器 可以直接再进行拖动创建布局 推荐使用手动编写方式进行开 ...