本次必须学习一个全新的概念-- 视图 (VIEW)。在前面的笔记中曾提到过,数据对象包含:表、视图、序列、索引和同义词。前面的笔记都是对表的想剖析,那么本次笔记就对视图的世界进行深入的剖析。

视图是通过对一个表或者是多个表查询得到的,是从表中抽出的逻辑上相关的数据集合。可是视图是一种虚表,它建立在已经存在表的基础之上。也能够理解为表中导出的“表”。视图定义所根据的表称为基表,有点类似与JAVA中的父类(基类)。

利用视图能够控制对数据的訪问。简化查询,能够避免直接对数据库中真实存在的表进行直接訪问,提高数据库的安全性。

创建视图



创建视图语法格式:

CREATE [OR ERPLACE ]  VIEW   view_name

as  子查询 [WITH READ ONLY] | [WITH CHECK OPTION]。

子查询能够是复杂的语句,如多个表之间的连接,子查询能够使用单行函数。能够通过给子查询中的列定义别名

来为视图的列定义成想要的名字。

例:创建视图,依赖emp表。

SQL> create view emp_view 

  2  as select empno ,ename ,sal from emp ;

 

View created

在用soctt用户运行上述语句的时候。可能会提示,没有创建视图的权限。可用以下的操作解决。

Oracle - OraClient10g_home1 --> Oracle EnterPrise Manager Console -->连接身份DBA

-->安全性-->用户-->scott --> 双击-->系统 --> 加入create any view 权限-->确定

如今对视图进行查询。

SQL> select * from  emp_view ;

 

EMPNO ENAME            SAL

----- ---------- ---------

 7369 SMITH         800.00

 7499 ALLEN        1600.00

 7521 WARD         1250.00

 7566 JONES        2975.00

 7654 MARTIN       1250.00

 7698 BLAKE        2850.00

 7782 CLARK        2450.00

 7788 SCOTT        3000.00

 7839 KING         5000.00

 7844 TURNER       1500.00

 7876 ADAMS        1100.00

 7900 JAMES         950.00

 7902 FORD         3000.00

 7934 MILLER       1300.00

 

14 rows selected

emp_view视图定义之后。在此创建emp_view 视图时,会提示名称已经由现有对象使用,说明视图的名称不

同意反复。

假设想依旧使用emp_view视图,能够使用 :

create or replace view emp_view as select empno ,ename ,sal from emp 。

尽管已经创

建了emp_view语句,仍然能够创建成功。

系统会删除emp_view视图,在创建一个新的视图。对视图仍然能够

进行相关的插入更新操作。对视图的操作都会返回到基表中。和直接对表的操作效果一样。

例:对视图进行插入删除操作。将ename为JAMES的工资改为2000 。插入一条新的数据。

SQL> update emp_view set sal = 2000 where ename = 'JAMES' ;

SQL> insert into emp_view values(7935 , 'zhangsan' , 5000);

以下看一下操作结果:

SQL> select * from emp_view where ename = 'JAMES' ;

 

EMPNO ENAME            SAL

----- ---------- ---------

 7900 JAMES        2000.00

 

SQL> select * from emp  where ename = 'JAMES' ;

 

EMPNO ENAME      JOB         MGR HIREDATE          SAL      COMM DEPTNO

----- ---------- --------- ----- ----------- --------- --------- ------

 7900 JAMES      CLERK      7698 1981/12/3     2000.00               30

SQL> select * from emp_view  where ename='zhangsan' ; 

 

EMPNO ENAME            SAL

----- ---------- ---------

 7935 zhangsan     5000.00

 

SQL> select * from emp where ename='zhangsan';

 

EMPNO ENAME      JOB         MGR HIREDATE          SAL      COMM DEPTNO

----- ---------- --------- ----- ----------- --------- --------- ------

 7935 zhangsan                                 5000.00

上面使用DML语句进行了插入和更新操作。可是视图使用DML时另一些特别的规定:

当视图定义中包括下面元素时,不能使用delete:

组函数、GROUP BY 、DISTINST 和 ROWNUM 伪列。

当视图定义中包括下面元素时,不能使用update:

组函数、GROUP BY 、DISTINST 、 ROWNUM 伪列和列的定义表达式。

当视图定义中包括下面元素时,不能使用insert:

组函数、GROUP BY 、DISTINST 、 ROWNUM 伪列、列的定义表达式和表中非空的列在视图中未包含。

假设创建的视图仅仅是为了让人浏览的内容而不能改动或者插入新的数据的话,那么须要在创建视图的时候加入限制(with read only) 仅仅读的 。

create or replace view emp_view

as select empno ,ename ,sal from emp 

with read only

此时在运行update语句 update emp_view set sal = 2000 where ename = 'JAMES',会出现

ORA-01733: 此处不同意虚拟列提示 。

with check option :不能更新视图的创建条件。此处不在赘述。

前面在运行多表查询的时候。有这种一条语句,将emp表和dept表进行联立。

select empno  ,ename , dname ,e.deptno

from emp e , dept d 

where d.deptno  = e.deptno

EMPNO ENAME      DNAME          DEPTNO

----- ---------- -------------- ------

 7369 SMITH      RESEARCH           20

 7499 ALLEN      SALES              30

 7521 WARD       SALES              30

 7566 JONES      RESEARCH           20

 7654 MARTIN     SALES              30

 7698 BLAKE      SALES              30

 7782 CLARK      ACCOUNTING         10

 7788 SCOTT      RESEARCH           20

 7839 KING       ACCOUNTING         10

 7844 TURNER     SALES              30

 7876 ADAMS      RESEARCH           20

 7900 JAMES      SALES              30

 7902 FORD       RESEARCH           20

 7934 MILLER     ACCOUNTING         10

 

14 rows selected

假设在开发的过程中,要多次使用上面的多表连接的语句,那么肯定是很麻烦的。所以此时能够将上面多表查

询的结果建立成一个试图。

再次使用的时候就轻松多了 。

create view view_emp

as

select empno  ,ename , dname ,e.deptno

from emp e , dept d 

where d.deptno  = e.deptno

当运行select * from view_emp ;语句时,与上面的多表查询的效果是一样的。使用试图能够简化操作。

删除视图

基本的语法:

DROP VIEW view_name ;

删除视图仅仅是删除用户自己创建的视图,不会对基表中的数据产生影响。

例:删除上面定义的视图emp_view 。

drop view emp_name ;

Rownum 伪列

上面提到了一个新的知识点rownum 伪劣。以下进行详细的解释一下。rownum 有点类似与excel中的表示行

的序号。实际上这是一个列,伪劣,能够在每张表中出现。

例:查询表emp中的rownum 。

SQL> select rownum , empno from emp ;

 

    ROWNUM EMPNO

---------- -----

         1  7369

         2  7499

         3  7521

         4  7566

         5  7654

         6  7698

         7  7782

         8  7788

         9  7839

        10  7844

        11  7876

        12  7900

        13  7902

        14  7934

        15  7935

 

15 rows selected

假设如今想要查询工资从高到低的前五条的数据,那么

SQL> select rownum , empno,sal from emp where rownum <= 5 order by sal desc;

 

    ROWNUM EMPNO       SAL

---------- ----- ---------

         1  7935   5000.00

         5  7566   2975.00

         3  7499   1600.00

         4  7521   1250.00

         2  7369    800.00

观察上面的数据,尽管是依照sal从高到低的排序,可是却不是我们想高的最高的五条数据的排序。事实上rownum和empno之间有某种关系。想要打破这中关系,能够使用以下的语句。

select rownum , empno,sal

from(

   select rownum , empno,sal

    from emp order by sal desc

)

where rownum <= 5

ROWNUM EMPNO       SAL

---------- ----- ---------

         1  7935   5000.00

         2  7839   5000.00

         3  7788   3000.00

         4  7902   3000.00

         5  7566   2975.00

上面的查询结果才是我们想要的结果。

假设我们想要查询3到8之间的数据呢 ?能够使用以下的数据

select rn ,empno ,sal from(

  select rownum rn , empno,sal

  from(

    select rownum , empno,sal

    from emp order by sal desc

  )

)

where rn >=3 and rn <=8

RN        EMPNO       SAL

------ ----- ---------

     3  7902   3000.00

     4  7788   3000.00

     5  7566   2975.00

     6  7698   2850.00

     7  7782   2450.00

     8  7900   2000.00

 

6 rows selected

上面给rownum 起了一个别名,将这个伪劣化为了一个实实在在存在的列。便能够进行 where rn > = 3 和 rn

<=8的操作了。

注意:

对 ROWNUM仅仅能使用
< 或
<=, 而用=, >, >=
都将不能返回不论什么数据。

Oracle 学习笔记 11 -- 视图 (VIEW)的更多相关文章

  1. Oracle学习笔记三 SQL命令

    SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)  

  2. Spring MVC 学习笔记11 —— 后端返回json格式数据

    Spring MVC 学习笔记11 -- 后端返回json格式数据 我们常常听说json数据,首先,什么是json数据,总结起来,有以下几点: 1. JSON的全称是"JavaScript ...

  3. Django:学习笔记(9)——视图

    Django:学习笔记(9)——视图 基础视图 基于函数的视图,我们需要在使用条件语句来判断请求类型,并分支处理.但是在基于类的视图中,我们可以在类中定义不同请求类型的方法来处理相对应的请求. 基于函 ...

  4. Oracle学习笔记—数据字典和常用命令(转载)

    转载自: oracle常用数据字典和SQL语句总结 Oracle常用命令大全(很有用,做笔记) 一.Oracle数据字典 数据字典是Oracle存放有关数据库信息的地方,其用途是用来描述数据的.比如一 ...

  5. Spring 源码学习笔记11——Spring事务

    Spring 源码学习笔记11--Spring事务 Spring事务是基于Spring Aop的扩展 AOP的知识参见<Spring 源码学习笔记10--Spring AOP> 图片参考了 ...

  6. Ext.Net学习笔记11:Ext.Net GridPanel的用法

    Ext.Net学习笔记11:Ext.Net GridPanel的用法 GridPanel是用来显示数据的表格,与ASP.NET中的GridView类似. GridPanel用法 直接看代码: < ...

  7. SQL反模式学习笔记11 限定列的有效值

    目标:限定列的有效值,将一列的有效字段值约束在一个固定的集合中.类似于数据字典. 反模式:在列定义上指定可选值 1. 对某一列定义一个检查约束项,这个约束不允许往列中插入或者更新任何会导致约束失败的值 ...

  8. oracle学习笔记第一天

    oracle学习笔记第一天 --oracle学习的第一天 --一.几个基础的关键字   1.select select (挑选) 挑选出显示的--列--(可以多列,用“,”隔开,*表示所有列),为一条 ...

  9. golang学习笔记11 golang要用jetbrain的golang这个IDE工具开发才好

    golang学习笔记11   golang要用jetbrain的golang这个IDE工具开发才好  jetbrain家的全套ide都很好用,一定要dark背景风格才装B   从File-->s ...

随机推荐

  1. WinForm控件复杂数据绑定常用数据源(对Combobox,DataGridView等控件DataSource赋值的多种方法)

    开始以前,先认识一下WinForm控件数据绑定的两种形式,简单数据绑定和复杂数据绑定. 1) 简单数据绑定 简单的数据绑定是将用户控件的某一个属性绑定至某一个类型实例上的某一属性.采用如下形式进行绑定 ...

  2. node初步一:HTTP请求

    一. 创建pathtest.js文件 var http= require('http' ); var url= require('url' ); function start (){ function ...

  3. ThinkPHP URL模式和URL重写

    现在用的版本是TP3.1.3,这两天总是遇到NotFound的错误,解析路径错误,所以认真研究了一下手册,发现问题出在URL模式上面. URL模式 一般是使用U方法来生成路径,U方法的定义规则如下(方 ...

  4. php之面向对象(2)

    注意:看这篇文章之前建议看看之前的文章,因为内容之间衔接性比较强.勿喷.. 面向对象,是一种思维模式的名字,并不是指某种特定的写法,面向对象简称oop,思路的核心在于:什么时候 什么东西 做什么. 编 ...

  5. HDU 3507 Print Article 斜率优化

    Print Article Time Limit: 9000/3000 MS (Java/Others)    Memory Limit: 131072/65536 K (Java/Others)To ...

  6. Codeforces Round #205 (Div. 2) : A

    题意: 要求找到最少次数的交换次数使得两组数都是偶数: 很明显答案要么是0,要么是1,或者不管怎么交换都不行(-1): 所以: #include<cstdio> #define maxn ...

  7. Book of Evil

    Codeforces Round #196 (Div. 2) D:http://codeforces.com/contest/337/status/D 题意:给你一个树,然后树中有一m个点,求到这m个 ...

  8. 基于android的Socket通信

    一.Socket通信简介 Android与服务器的通信方式主要有两种,一是Http通信,一是Socket通信.两者的最大差异在于,http连接使用的是“请求—响应方式”,即在请求时建立连接通道,当客户 ...

  9. struts2+jsp+jquery+Jcrop实现图片裁剪并上传

    <1> 使用html标签上传需要裁剪的大图. <2> 在页面呈现大图,使用Jcrop(Jquery)对大图进行裁剪,并且可以进行预览. <3> 选择好截取部分之后发 ...

  10. Linux iconv使用

    iconv [选项]文件 输入/输出格式规范:-f, --from-code=名称 原始文本编码-t, --to-code=名称 输出编码 信息:-l, --list 列举所有已知的字符集 输出控制: ...