热门标签 | 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

推荐阅读
  • Java String与StringBuffer的区别及其应用场景
    本文主要介绍了Java中String和StringBuffer的区别,String是不可变的,而StringBuffer是可变的。StringBuffer在进行字符串处理时不生成新的对象,内存使用上要优于String类。因此,在需要频繁对字符串进行修改的情况下,使用StringBuffer更加适合。同时,文章还介绍了String和StringBuffer的应用场景。 ... [详细]
  • 本文介绍了adg架构设置在企业数据治理中的应用。随着信息技术的发展,企业IT系统的快速发展使得数据成为企业业务增长的新动力,但同时也带来了数据冗余、数据难发现、效率低下、资源消耗等问题。本文讨论了企业面临的几类尖锐问题,并提出了解决方案,包括确保库表结构与系统测试版本一致、避免数据冗余、快速定位问题等。此外,本文还探讨了adg架构在大版本升级、上云服务和微服务治理方面的应用。通过本文的介绍,读者可以了解到adg架构设置的重要性及其在企业数据治理中的应用。 ... [详细]
  • MyBatis错题分析解析及注意事项
    本文对MyBatis的错题进行了分析和解析,同时介绍了使用MyBatis时需要注意的一些事项,如resultMap的使用、SqlSession和SqlSessionFactory的获取方式、动态SQL中的else元素和when元素的使用、resource属性和url属性的配置方式、typeAliases的使用方法等。同时还指出了在属性名与查询字段名不一致时需要使用resultMap进行结果映射,而不能使用resultType。 ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文介绍了使用postman进行接口测试的方法,以测试用户管理模块为例。首先需要下载并安装postman,然后创建基本的请求并填写用户名密码进行登录测试。接下来可以进行用户查询和新增的测试。在新增时,可以进行异常测试,包括用户名超长和输入特殊字符的情况。通过测试发现后台没有对参数长度和特殊字符进行检查和过滤。 ... [详细]
  • 本文详细介绍了MysqlDump和mysqldump进行全库备份的相关知识,包括备份命令的使用方法、my.cnf配置文件的设置、binlog日志的位置指定、增量恢复的方式以及适用于innodb引擎和myisam引擎的备份方法。对于需要进行数据库备份的用户来说,本文提供了一些有价值的参考内容。 ... [详细]
  • 使用Ubuntu中的Python获取浏览器历史记录原文: ... [详细]
  • 本文由编程笔记小编整理,介绍了PHP中的MySQL函数库及其常用函数,包括mysql_connect、mysql_error、mysql_select_db、mysql_query、mysql_affected_row、mysql_close等。希望对读者有一定的参考价值。 ... [详细]
  • 本文介绍了Oracle数据库中tnsnames.ora文件的作用和配置方法。tnsnames.ora文件在数据库启动过程中会被读取,用于解析LOCAL_LISTENER,并且与侦听无关。文章还提供了配置LOCAL_LISTENER和1522端口的示例,并展示了listener.ora文件的内容。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • Oracle分析函数first_value()和last_value()的用法及原理
    本文介绍了Oracle分析函数first_value()和last_value()的用法和原理,以及在查询销售记录日期和部门中的应用。通过示例和解释,详细说明了first_value()和last_value()的功能和不同之处。同时,对于last_value()的结果出现不一样的情况进行了解释,并提供了理解last_value()默认统计范围的方法。该文对于使用Oracle分析函数的开发人员和数据库管理员具有参考价值。 ... [详细]
  • 本文详细介绍了在ASP.NET中获取插入记录的ID的几种方法,包括使用SCOPE_IDENTITY()和IDENT_CURRENT()函数,以及通过ExecuteReader方法执行SQL语句获取ID的步骤。同时,还提供了使用这些方法的示例代码和注意事项。对于需要获取表中最后一个插入操作所产生的ID或马上使用刚插入的新记录ID的开发者来说,本文提供了一些有用的技巧和建议。 ... [详细]
  • 本文介绍了一个在线急等问题解决方法,即如何统计数据库中某个字段下的所有数据,并将结果显示在文本框里。作者提到了自己是一个菜鸟,希望能够得到帮助。作者使用的是ACCESS数据库,并且给出了一个例子,希望得到的结果是560。作者还提到自己已经尝试了使用"select sum(字段2) from 表名"的语句,得到的结果是650,但不知道如何得到560。希望能够得到解决方案。 ... [详细]
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社区 版权所有