oracle查询 view,oracle view
视图具有以下优点
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相关推荐
- oracle查询表唯一索引,oracle查询索引(oracle查看表索引)
oracle查询索引(oracle查看表索引) 2020-07-24 11:01:26 共10个回答 选中表右键View然后查看index 通过PL/SQL可以直接查看某表是否建索引,通过SQL查询s ...
- oracle查有哪些数据库,oracle查询数据库(oracle查询所有数据库)
oracle查询数据库(oracle查询所有数据库) 2020-07-24 12:01:17 共10个回答 PLsql查询工具便可查询 你指所有的表吗?如果你想查数据库中所有的表的话,可以查询sele ...
- oracle 查询天,Oracle查询_ 单表查询
前面我们详解了关于Oracle的增删改,今天让我们接着来学习Oracle的查询吧, Oracle中查询可是重头戏噢!!!跟着煌sir的步伐,走位,走位~~~ 小知识锦囊 在此前,先讲解一个小知识点 O ...
- oracle查询快慢,Oracle查询连接数和sql快慢脚本
Oracle查询连接数和sql快慢脚本 一.查询执行最慢的sql select * from (select sa.SQL_TEXT, sa.SQL_FULLTEXT, sa.EXECUTIONS & ...
- oracle查询元数据,Oracle Spatial-元数据及SDO_GEOMETRY
一.空间表的元数据 将表的SDO_GEOMETRY列的所有对象作为一个空间层.Spatial需要对所有空间对象进行验证.创建索引和查询.此时需要为图层指定适当的元数据,该数据包含如下信息:维度.维度边 ...
- oracle查询dictionary,Oracle的DICTIONARY/DICT视图。
The Dictionary in the Data Dictionary Today's journey takes on a trip into Oracle's data dictionary, ...
- oracle 查询 ppt,oracle子查询.ppt
<oracle子查询.ppt>由会员分享,可在线阅读,更多相关<oracle子查询.ppt(26页珍藏版)>请在人人文库网上搜索. 1.子查询,目标,通过本章学习,您将可以: ...
- oracle 查询最高分,oracle高级查询
幕课oracle学习笔记 --!!!scott用户 --一.分组查询 --1.常用的分组函数:AVG(平均数),SUM,MIN,MAX,COUNT,WM_CONCAT(行转列) select avg( ...
- oracle查询file_name,Oracle DG环境下db_file_name_convert的实际意义
关于DG环境下备库数据文件重命名的问题: **前言:** 主要想表明DG环境下备库数据文件重命名的问题,以及db_file_name_convert与log_file_name_convert的作用. ...
- oracle查询字体,oracle查询字符集语句分享
(1)查看字符集(三条都是等价的) select * from v$nls_parameters where parameter='NLS_CHARACTERSET' select * from ...
最新文章
- Chapter 2 Open Book——8
- ie8一下解决圆角,阴影不兼容问题
- 为什么要在基类使用私有数据_为什么要使用函数
- 排序及查找----[(冒泡,快速)(拉格朗日,二分)]
- Google Earth的十个常用技巧应用
- CSS3 3D transform变换
- C语言弧长,在C ++中从给定角度的弧长?
- IntelliJ IDEA 设置Output (输出窗口)窗口字体大小
- sed 多行替换,多行模式处理字符串;一次替换
- 2019-数学建模美赛-B题翻译
- CentOS下转换网易云音乐ncm格式为mp3
- 基于QT和C++实现的停车场管理系统
- ab变频器22b用户手册_AB变频器 PowerFlex400用户手册.pdf
- 深度学习入门——神经元
- glew库安装和初始化
- Android应用开发自定义图片剪辑头像设置
- python简易爬虫
- 不经一番寒彻骨,怎得梅花扑鼻香,墙都不扶就服你
- QT 显示动态GIF
- 一种利用电磁能产生的共振引力波实现超光速飞行的机器
热门文章
- ApacheCN 翻译活动进度公告 2019.5.17
- python 找色点击_[原创]python实现触动精灵引擎找色找字函数,为机器学习添加手脚...
- 安全工具(免费杀毒软件Avast、免费防火墙费尔、免费木马清理工具arswp,AVG/Ewido,超级兔子)...
- 打印服务器后台程序没有运行,打印后台程序服务没有运行
- PHY之MDIO解析
- HTML5+CSS3从入门到精通随书光盘 ISO 镜像视频教程​
- java三国鼎立,网页游戏三国鼎立(武三国)一键服务端带教程及修改说明
- 播布客全部视频教程汇总
- VMware ESXi 7.0 U3c SLIC 2.6 Unlocker 集成 Intel NUC 网卡、USB 网卡和 NVMe 驱动
- php 简繁体,使用php实现简体转繁体的方法