热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

ORACLE视图(VIEW)

说ORACLE视图之前,有这样的需求我们先来想一下。有一张老师信息表,表中字段有:老师ID、姓名、婚姻状况、身份证号、代课科目;其中婚姻状况、身份证号教务处人可以查看,但对学生是禁止查看、保密的。此两种身份都用的同一张表,查看不同的结果怎么实现?

说ORACLE视图之前,有这样的需求我们先来想一下。 有一张老师信息表,表中字段有:老师ID、姓名、婚姻状况、身份证号、代课科目;其中婚姻状况、身份证号教务处人可以查看,但对学生是禁止查看、保密的。此两种身份都用的同一张表,查看不同的结果怎么实现?

说ORACLE视图之前,有这样的需求我们先来想一下。

有一张老师信息表,表中字段有:老师ID、姓名、婚姻状况、身份证号、代课科目;其中婚姻状况、身份证号教务处人可以查看,但对学生是禁止查看、保密的。此两种身份都用的同一张表,查看不同的结果怎么实现? .........这就用到了视图,限制需要保密的字段信息被学生看到。

视图时基于真实表的一个展现。它只是一个逻辑概念,视图中的数据来源于基表(真实表),几乎不占用物理存储空间;视图和普通表一样,可以进行增删改操做;视图保证了数据库数据的安全性。当然还有方便快捷性(如较复杂的SQL条件查询可以定义到一个视图中,直接查询该视图) 。先来了解如何定义一个视图:

1、视图完整定义语法:

CREATE[OR REPLACE][FORCE][NOFORCE]VIEW view_name

[(column_name)[,….n]]

AS

Select_statement

[WITH CHECK OPTION[CONSTRAINT constraint_name]]

[WITH READ ONLY]

OR REPLACE --如视图存在替换存在试图

FORCE][NOFORCE --基表不存在FORCE强行创建; NOFORCE不创建(默认)

WITH CHECK OPTION[CONSTRAINT constraint_name] --对视图DML操纵时,是否验证定义视图SQL的WHERE条件。

WITH READ ONLY --定义只读视图

2、创建视图、以基表classes为例

SQL> SELECT * FROM classes;
CID CNAME
--------------------------------------- ----------
1 0901
2 0902
3 0903

为classes表创建默认视图classes_view语句

SQL> CREATE OR REPLACE NOFORCE VIEW classes_view
2 AS
3 SELECT * FROM classes
4 ;
View created

创建视图成功;上面说到视图和普通表一样,可以进行增删改操作,以新增数据到视图为例说明(修改、删除同新增一样这里不一一列举)

SQL> insert into classes_view values(4,1111);
1 row inserted

SQL> commit;
Commit complete

SQL> SELECT * FROM classes_view;
CID CNAME
--------------------------------------- ----------
1 0901
2 0902
3 0903
4 1111

同样基表中也存在该条新增数据。

SQL> SELECT * FROM classes;
CID CNAME
--------------------------------------- ----------
1 0901
2 0902
3 0903
4 1111

为classes表创建带查询条件视图classes_view

SQL> CREATE OR REPLACE NOFORCE VIEW classes_view
2 AS
3 SELECT * FROM classes WHERE cid<=2
4 ;
View created

SQL> SELECT * FROM CLASSES_VIEW;
CID CNAME
--------------------------------------- ----------
1 0901
2 0902

--因为创建视图时带WHERE条件cid<=2,所有视图中就两条信息

SQL> SELECT * FROM CLASSES;
CID CNAME
--------------------------------------- ----------
1 0901
2 0902
3 0903
4 1111

在CLASSES_VIEW视图新增一条cid为5的信息

SQL> INSERT INTO CLASSES_VIEW VALUES(5,'2222');
1 row inserted

SQL> COMMIT;
Commit complete

--视图上添加数据成功。查询视图显示结果:

SQL> SELECT * FROM CLASSES_VIEW;
CID CNAME
--------------------------------------- ----------
1 0901
2 0902

???怎么没包含我们刚新添加的数据呢?新增数据上哪去了?我们上面说到,操作视图数据实际上操作的是基表,也就是数据保存到了基表CLASSES表中。那么为什么我们定义的视图中查不到了,回看我们视图定义语法:

SQL> CREATE OR REPLACE NOFORCE VIEW classes_view
2 AS
3 SELECT * FROM classes WHERE cid<=2
4 ;

是因为有WHERE条件限制的,带条件视图不显示没有满足条件的数据,所以也就看不到。那有人就要问了,既然视图只显示满足WHERE条件的信息,那么如何控制不满足视图WHERE条件的信息从视图中录入(insert,update)呢? 使用视图关键字:WITH CHECK OPTION ,下面讲解WITH CHECK OPTION如何控制非满足条件如何禁止从视图中录入

--为classes表创建带查询条件WITH CHECK OPTION视图classes_view

SQL> CREATE OR REPLACE NOFORCE VIEW classes_view
2 AS
3 SELECT * FROM classes WHERE cid<=2
4 WITH CHECK OPTION
5 ;
View created

SQL> select * from classes_view;
CID CNAME
--------------------------------------- ----------
1 0901
2 0902

创建视图成功,视图中只包含约束条件cid<=2数据为2条,而基表数据实为4条;在视图中新增一条cid为5数据就报错,因为视图有where条件约束

SQL> INSERT INTO CLASSES_VIEW VALUES(5,2222);
INSERT INTO CLASSES_VIEW VALUES(5,2222)
ORA-01402: 视图 WITH CHECK OPTIDN where 子句违规

插入满足where条件数据就能插入成功,如下插入<=2的数据0:

SQL> INSERT INTO CLASSES_VIEW VALUES(0,'0001');
1 row inserted

SQL> commit;
Commit complete

SQL> select * from classes_view;
CID CNAME
--------------------------------------- ----------
0 0001
1 0901
2 0902

修改视图:ORACLE没有提供修改视图的操纵语句,如想修改视图使用replace关键字

CREATE OR REPLACE VIEW classes_view
AS
SELECT * FROM classes

View created

删除视图

SQL> DROP VIEW classes_view;
View dropped

推荐阅读
  • 解决phpMyAdmin运行错误:mysqli_init(): 属性访问尚未允许
    本文探讨了在使用phpMyAdmin过程中遇到的mysqli_init()函数错误,并提供了有效的解决方案。 ... [详细]
  • 本文详细介绍ThinkPHP框架中的cache方法,涵盖其功能、参数配置及使用场景,特别指出从3.1.2版本起,cache方法已被S方法取代。 ... [详细]
  • 应用程序配置详解
    本文介绍了配置文件的关键特性及其在不同场景下的应用,重点探讨了Machine.Config和Web.Config两种主要配置文件的用途和配置方法。文章还详细解释了如何利用XML格式的配置文件来调整应用程序的行为,包括自定义配置、错误处理、身份验证和授权设置。 ... [详细]
  • 本文探讨了如何在C#应用程序中有效处理来自两个不同数据库的数据,特别是当需要从一个数据库中选择不在另一个大型集合中的ID时遇到的挑战和解决方案。 ... [详细]
  • 在执行大量数据导入操作至第6003435行时,系统抛出错误0xc0202009,提示OLE DB错误,具体错误信息为从BCP客户端接收到的列值对列ID 17无效。 ... [详细]
  • 本文详细解析了在Oracle数据库操作中遇到的ORA-01846错误,该错误通常出现在尝试使用NEXT_DAY函数处理日期时,因客户端和服务器端字符集不匹配导致的问题。文章不仅提供了错误的具体表现,还深入分析了错误原因,并给出了多种解决方案。 ... [详细]
  • C#里时关闭子窗口时base.Dispose(disposing)报错:ValueDispose()cannotbecalledwhiledoingCreateHandle(). ... [详细]
  • 本文探讨了在执行SQL查询时遇到的因字符集不同而导致查询结果差异的问题,特别是涉及中文字符时。文章分析了在不同字符集设置下,SQL查询结果的变化,并提供了详细的解决方案。 ... [详细]
  • 掌握Python岗位,你需要了解的关键技能
    最近,在社交平台脉脉上,一条关于Python岗位的消息引起了广泛关注。本文将探讨Python岗位的实际价值,并深入解析阿里巴巴等大公司在面试Python开发者时常见的问题。 ... [详细]
  • 本文详细探讨了JSP环境下数据库连接的实现方法,包括环境配置、代码示例以及常见的连接问题及其解决方案。 ... [详细]
  • 通过阅读本文,您将全面了解如何在数据库表中有效利用索引提升查询效率。本文不仅探讨了索引为何能提高查询速度,还深入分析了不同类型的索引结构及其在SQL Server中的实现方式。 ... [详细]
  • 本文探讨了在 MySQL 数据库中使用 LIKE 语句进行模糊查询并结合分页处理时可能遇到的问题,并提出了解决这些潜在陷阱的有效方法。 ... [详细]
  • 一、数据更新操作DML语法中主要包括两个内容:查询与更新,更新主要包括:增加数据、修改数据、删除数据。其中这些操作是离不开查询的。1、增加数据语法:INSERTINTO表名称[(字 ... [详细]
  • SQL注入实验:SqliLabs第38至45关解析
    本文深入探讨了SqliLabs项目中的第38至45关,重点讲解了堆叠注入(Stacked Queries)的应用技巧及防御策略。通过实际案例分析,帮助读者理解如何利用和防范此类SQL注入攻击。 ... [详细]
  • KKCMS代码审计初探
    本文主要介绍了KKCMS的安装过程及其基本功能,重点分析了该系统中存在的验证码重用、SQL注入及XSS等安全问题。适合初学者作为入门指南。 ... [详细]
author-avatar
jack_liujh_598
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有