视图具有以下优点

1、限制用户只能通过视图检索数据。这样就可以对最终用户屏蔽创建视图所基于的底层基表。

2、可以将复杂查询编写为视图。这样可以对最终用户屏蔽一定的复杂性。

3、限制某个视图只能访问基表中的部分数据,这样可以实现另外一层安全性,并且可以对最终用户屏蔽部分行。

CREATE [OR REPLACE] VIEW [ { FORCE | NOFORCE }] view_name

[ (alias_name[,alias_name ...])] AS subquery

[ WITH { CHECK OPTION | READ ONLY } CONSTRAINT constraint_name];

其中OR REPLACE 说明如果视图已经存在,就替换现有视图。

FROCE说明即使基表不存在,也要创建视图,

NOFORCE 说明如果基表不存在,就不创建视图,NOFORCE是默认值。

subquery指定一个子查询。

WIHT CHECK OPTION 说明只有子查询检索的行才能被插入,修改、删除。默认情况下,在插入、修改、删除行之前不会检索这些行是否被子查询检索

WIHT READ ONLY 说明只能对基表中的行进行只读访问。

--简单视图

CREATEVIEW v_cheap_products1

AS

SELECT *

FROM products

WHERE price<15;

CREATE VIEW v_employees

AS

SELECTemployee_id,manager_id,first_name,last_name,title

FROM employees;

--对视图执行insert操作

INSERTINTO v_cheap_products1 (

product_id,product_type_id,name,price

) values (

12,1,'Western Front',13.50

);

/**注意:只能对简单视图执行DML操作;复杂视图不支持DML操作.*****************/

--由于v_cheap_products没有使用WITH CHECK OPTION,因此可以插入、修改、删除那些子查询不能检索的行。

INSERTINTO v_cheap_products1 (

product_id,product_type_id,name,price

) values (

14,1,'Eastern Front',16.5

);

--以上插入了子查询不能检索的行,因此以下检索不到数据

SELECT *

FROMv_cheap_products

WHEREproduct_id =14;

--创建具有CHECK OPTION约束的视图:通过为视图添加CHECK OPTION约束,可以指定对视图执行DML操作必须满足子查询的条件。

CREATEVIEW v_cheap_products2

AS

SELECT *

FROM products

WHERE price <15

WITH CHECK OPTION CONSTRAINT cheap_products_v2_price;

--插入以下数据会报错

INSERTINTOv_cheap_products (

product_id,product_type_id,name,price

) values (

14,1,'Eastern Front',16.5

);

--创建只读视图:对于只读视图,不能对其执行DML操作

CREATEVIEW v_cheap_products3

AS

SELECT *

FROM products

WHERE price <15

WITH READ ONLY CONSTRAINT cheap_products_v3_price;

--创建复杂视图

CREATEVIEWv_products_and _types

AS

SELECT p.name product_name,pt.nameproduct_type_name,p.price

FROM products p FULL OUTER JOIN product_types pt

USING(product_type_id)

CREATEVIEWv_employee_salary_grades

AS

SELECT e.first_name, e.last_name, e.title, e.salary,sa.salary_grade_id

FROM employees e INNER JOINsalary_grades sgON e.salary BETWEEN sg.low_salary AND sg.high_salary;

--下面这个例子创建视图v_product_average,子查询使用

/*WHERE 子句对products表中的行进行过滤,只保留那些价格低于$15的记录

GROUP BY子句对剩余的行根据product_type_id列进行分组

HAVING 子句对分组进行过滤,只保留那些平均价格低于$13的分组*/

CREATEVIEWv_product_average

AS

SELECTproduct_type_id,AVG(price) average_price

FROM products

WHERE price <15

GROUPBYproduct_type_id

HAVINGAVG(price) >13;

--修改视图CREATE OR REPLACE,使用ALTER VIEW可以修改视图的约束

CREATE OR REPLACE VIEW v_product_average

AS

SELECTproduct_type_id,AVG(price) average_price

FROM products

WHERE price <12

GROUPBYproduct_type_id

HAVINGAVG(price) >11;

--获取视图定义信息describe

DESC v_cheap_products3

--获取用户所创建的视图信息

select * from user_views;

--获取可以访问的视图信息

select * from all_views;

--获取有关视图的约束信息

select constraint_name,constraint_type,status

fromuser_constraints

where table_name in ('V_CHEAP_PRODUCTS1','V_CHEAP_PRODUCTS2');

oracle查询 view,oracle view相关推荐

  1. oracle查询表唯一索引,oracle查询索引(oracle查看表索引)

    oracle查询索引(oracle查看表索引) 2020-07-24 11:01:26 共10个回答 选中表右键View然后查看index 通过PL/SQL可以直接查看某表是否建索引,通过SQL查询s ...

  2. oracle查有哪些数据库,oracle查询数据库(oracle查询所有数据库)

    oracle查询数据库(oracle查询所有数据库) 2020-07-24 12:01:17 共10个回答 PLsql查询工具便可查询 你指所有的表吗?如果你想查数据库中所有的表的话,可以查询sele ...

  3. oracle 查询天,Oracle查询_ 单表查询

    前面我们详解了关于Oracle的增删改,今天让我们接着来学习Oracle的查询吧, Oracle中查询可是重头戏噢!!!跟着煌sir的步伐,走位,走位~~~ 小知识锦囊 在此前,先讲解一个小知识点 O ...

  4. oracle查询快慢,Oracle查询连接数和sql快慢脚本

    Oracle查询连接数和sql快慢脚本 一.查询执行最慢的sql select * from (select sa.SQL_TEXT, sa.SQL_FULLTEXT, sa.EXECUTIONS & ...

  5. oracle查询元数据,Oracle Spatial-元数据及SDO_GEOMETRY

    一.空间表的元数据 将表的SDO_GEOMETRY列的所有对象作为一个空间层.Spatial需要对所有空间对象进行验证.创建索引和查询.此时需要为图层指定适当的元数据,该数据包含如下信息:维度.维度边 ...

  6. oracle查询dictionary,Oracle的DICTIONARY/DICT视图。

    The Dictionary in the Data Dictionary Today's journey takes on a trip into Oracle's data dictionary, ...

  7. oracle 查询 ppt,oracle子查询.ppt

    <oracle子查询.ppt>由会员分享,可在线阅读,更多相关<oracle子查询.ppt(26页珍藏版)>请在人人文库网上搜索. 1.子查询,目标,通过本章学习,您将可以: ...

  8. oracle 查询最高分,oracle高级查询

    幕课oracle学习笔记 --!!!scott用户 --一.分组查询 --1.常用的分组函数:AVG(平均数),SUM,MIN,MAX,COUNT,WM_CONCAT(行转列) select avg( ...

  9. oracle查询file_name,Oracle DG环境下db_file_name_convert的实际意义

    关于DG环境下备库数据文件重命名的问题: **前言:** 主要想表明DG环境下备库数据文件重命名的问题,以及db_file_name_convert与log_file_name_convert的作用. ...

  10. oracle查询字体,oracle查询字符集语句分享

    (1)查看字符集(三条都是等价的) select * from v$nls_parameters  where parameter='NLS_CHARACTERSET' select * from  ...

最新文章

  1. Chapter 2 Open Book——8
  2. ie8一下解决圆角,阴影不兼容问题
  3. 为什么要在基类使用私有数据_为什么要使用函数
  4. 排序及查找----[(冒泡,快速)(拉格朗日,二分)]
  5. Google Earth的十个常用技巧应用
  6. CSS3 3D transform变换
  7. C语言弧长,在C ++中从给定角度的弧长?
  8. IntelliJ IDEA 设置Output (输出窗口)窗口字体大小
  9. sed 多行替换,多行模式处理字符串;一次替换
  10. 2019-数学建模美赛-B题翻译
  11. CentOS下转换网易云音乐ncm格式为mp3
  12. 基于QT和C++实现的停车场管理系统
  13. ab变频器22b用户手册_AB变频器 PowerFlex400用户手册.pdf
  14. 深度学习入门——神经元
  15. glew库安装和初始化
  16. Android应用开发自定义图片剪辑头像设置
  17. python简易爬虫
  18. 不经一番寒彻骨,怎得梅花扑鼻香,墙都不扶就服你
  19. QT 显示动态GIF
  20. 一种利用电磁能产生的共振引力波实现超光速飞行的机器

热门文章

  1. ApacheCN 翻译活动进度公告 2019.5.17
  2. python 找色点击_[原创]python实现触动精灵引擎找色找字函数,为机器学习添加手脚...
  3. 安全工具(免费杀毒软件Avast、免费防火墙费尔、免费木马清理工具arswp,AVG/Ewido,超级兔子)...
  4. 打印服务器后台程序没有运行,打印后台程序服务没有运行
  5. PHY之MDIO解析
  6. HTML5+CSS3从入门到精通随书光盘 ISO 镜像视频教程​
  7. java三国鼎立,网页游戏三国鼎立(武三国)一键服务端带教程及修改说明
  8. 播布客全部视频教程汇总
  9. VMware ESXi 7.0 U3c SLIC 2.6 Unlocker 集成 Intel NUC 网卡、USB 网卡和 NVMe 驱动
  10. php 简繁体,使用php实现简体转繁体的方法