ORACLE SQL视图

视图是什么呢?

视图是一种虚表。  

视图建立在已有表的基础上, 视图赖以建立的这些表称为基表。

向视图提供数据内容的语句为 SELECT 语句, 可以将视图理解为存储起来的 SELECT 语句.

视图向用户提供基表数据的另一种表现形式

 

那么视图:

  1. 可以创建和修改视图的定义,删除视图
  2. 可以从视图中查询数据
  3. 可以通过视图插入,修改和删除视图
  4. 可以使用Top-N分析视图

 

常用的数据可对象有:

ORACLE SQL视图_第1张图片

 

那么我们为什么会使用视图呢:

1.因为它控制数据访问

2.简化查询

3.避免重复访问相同的数据

视图有分两种,简单视图和复杂视图,看下图简单了解下

ORACLE SQL视图_第2张图片

 

下面我们看下如何创建视图

CREATE VIEW empvu80

 AS SELECT  employee_id, last_name, salary

    FROM    employees

WHERE   department_id = 80;

 

这是简单的创建视图

 

在创建视图时可以在子查询中给列定义别名:看代码

CREATE VIEW salvu50

 AS SELECT  employee_id ID_NUMBER, last_name NAME,

            salary*12 ANN_SALARY

    FROM    employees

WHERE   department_id = 50;

 

修改视图可以使用CREATE OR REPLACE VIEW 子句修改视图

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;

 

我们看下复杂的视图创建

CREATE VIEW dept_sum_vu

  (name, minsal, maxsal, avgsal)

AS SELECT  d.department_name, MIN(e.salary),

             MAX(e.salary),AVG(e.salary)

   FROM      employees e, departments d

   WHERE     e.department_id = d.department_id

   GROUP BY  d.department_name;

再看下使用视图的一些规定

1.可以在简单视图中执行 DML 操作

2.当视图定义中包含以下元素之一时不能使用delete:

3.组函数

4.GROUP BY 子句

5.DISTINCT 关键字

6.ROWNUM 伪列

当视图定义中包含以下元素之一时不能使用update:

1.组函数

2.GROUP BY子句

3.DISTINCT 关键字

4.ROWNUM 伪列

5.列的定义为表达式

当视图定义中包含以下元素之一时不能使insert:

1.组函数

2.GROUP BY 子句

3.DISTINCT 关键字

4.ROWNUM 伪列

5.列的定义为表达式

6.表中非空的列在视图定义中未包括

 

那我们既然可以使用DML操作那也就以为着可以屏蔽它

屏蔽DML的操作

可以使用 WITH READ ONLY 选项屏蔽对视图的DML 操作

任何 DML 操作都会返回一个Oracle server 错误

看下例子:

CREATE OR REPLACE VIEW empvu10

    (employee_number, employee_name, job_title)

AS SELECT employee_id, last_name, job_id

   FROM     employees

   WHERE    department_id = 10

   WITH READ ONLY;

删除视图只是删除视图的定义,并不会删除基表的数据

DROP VIEW empvu80;

Top-N 分析

查询最大的几个值的 Top-N 分析:

SELECT [column_list], ROWNUM  

FROM   (SELECT [column_list]

        FROM table

        ORDER  BY Top-N_column)

WHERE  ROWNUM <=  N;

注意:

对 ROWNUM 只能使用 < 或 <=, 而用 =, >, >= 都将不能返回任何数据。

你可能感兴趣的:(技术总结)