`
tntxia
  • 浏览: 1510370 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

视图的概念

 
阅读更多

视图的含义

从用户角度来看,一个视图是从一个特定的角度来查看数据库中的数据。从数据库系统内部来看,一个视图是由SELECT语句组成的查询定义的虚拟表。从数据库系统内部来看,视图是由一张或多张表中的数据组成的,从数据库系统外部来看,视图就如同一张表一样,对表能够进行的一般操作都可以应用于视图,例如查询,插入,修改,删除操作等。  视图是一个虚拟表,其内容由查询定义。同真实的表一样,视图包含一系列带有名称的列和行数据。但是,视图并不在数据库中以存储的数据值集形式存在。行和列数据来自由定义视图的查询所引用的表,并且在引用视图时动态生成。对其中所引用的基础表来说,视图的作用类似于筛选。定义视图的筛选可以来自当前或其它数据库的一个或多个表,或者其它视图。分布式查询也可用于定义使用多个异类源数据的视图。  视图是存储在数据库中的查询的SQL 语句,它主要出于两种原因:安全原因, 视图可以隐藏一些数据,如:社会保险基金表,可以用视图只显示姓名,地址,而不显示社会保险号和工资数等,另一原因是可使复杂的查询易于理解和使用。  视图:查看图形或文档的方式。  视图一经定义便存储在数据库中,与其相对应的数据并没有像表那样又在数据库中再存储一份,通过视图看到的数据只是存放在基本表中的数据。对视图的操作与对表的操作一样,可以对其进行查询、修改(有一定的限制)、删除。  当对通过视图看到的数据进行修改时,相应的基本表的数据也要发生变化,同时,若基本表的数据发生变化,则这种变化也可以自动地反映到视图中。

视图的作用

* 简单性。看到的就是需要的。视图不仅可以简化用户对数据的理解,也可以简化他们的操作。那些被经常使用的查询可以被定义为视图,从而使得用户不必为以后的操作每次指定全部的条件。  * 安全性。通过视图用户只能查询和修改他们所能见到的数据。数据库中的其它数据则既看不见也取不到。数据库授权命令可以使每个用户对数据库的检索限制到特定的数据库对象上,但不能授权到数据库特定行和特定的列上。通过视图,用户可以被限制在数据的不同子集上:  使用权限可被限制在基表的行的子集上。 使用权限可被限制在基表的列的子集上。 使用权限可被限制在基表的行和列的子集上。 使用权限可被限制在多个基表的连接所限定的行上。 使用权限可被限制在基表中的数据的统计汇总上。 使用权限可被限制在另一视图的一个子集上,或是一些视图和基表合并后的子集上。  * 逻辑数据独立性。视图可帮助用户屏蔽真实表结构变化带来的影响。

视图的优点

视图有很多优点,主要表现在:  ·视点集中  ·简化操作  ·定制数据  ·合并分割数据  ·安全性  1. 视点集中  视图集中即是使用户只关心它感兴趣的某些特定数据和他们所负责的特定任务。这样通过只允许用户看到视图中所定义的数据而不是视图引用表中的数据而提高了数据的安全性。  2. 简化操作  视图大大简化了用户对数据的操作。因为在定义视图时,若视图本身就是一个复杂查询的结果集,这样在每一次执行相同的查询时,不必重新写这些复杂的查询语句,只要一条简单的查询视图语句即可。可见视图向用户隐藏了表与表之间的复杂的连接操作。  3. 定制数据  视图能够实现让不同的用户以不同的方式看到不同或相同的数据集。因此,当有许多不同水平的用户共用同一数据库时,这显得极为重要。  4. 合并分割数据  在有些情况下,由于表中数据量太大,故在表的设计时常将表进行水平分割或垂直分割,但表的结构的变化却对应用程序产生不良的影响。如果使用视图就可以重新保持原有的结构关系,从而使外模式保持不变,原有的应用程序仍可以通过视图来重载数据。  5. 安全性  视图可以作为一种安全机制。通过视图用户只能查看和修改他们所能看到的数据。其它数据库或表既不可见也不可以访问。如果某一用户想要访问视图的结果集,必须授予其访问权限。视图所引用表的访问权限与视图权限的设置互不影响。

视图的安全性

视图的安全性可以防止未授权用户查看特定的行或列,是用户只能看到表中特定行的方法如下:  1 在表中增加一个标志用户名的列;  2 建立视图,是用户只能看到标有自己用户名的行;  3 把视图授权给其他用户。

逻辑数据独立性

视图可以使应用程序和数据库表在一定程度上独立。如果没有视图,应用一定是建立在表上的。有了视图之后,程序可以建立在视图之上,从而程序与数据库表被视图分割开来。视图可以在以下几个方面使程序与数据独立:  1 如果应用建立在数据库表上,当数据库表发生变化时,可以在表上建立视图,通过视图屏蔽表的变化,从而应用程序可以不动。  2 如果应用建立在数据库表上,当应用发生变化时,可以在表上建立视图,通过视图屏蔽应用的变化,从而使数据库表不动。  3 如果应用建立在视图上,当数据库表发生变化时,可以在表上修改视图,通过视图屏蔽表的变化,从而应用程序可以不动。  4 如果应用建立在视图上,当应用发生变化时,可以在表上修改视图,通过视图屏蔽应用的变化,从而数据库可以不动。

视图的书写格式

CREATE VIEW <视图名>【(列名组)】AS <子查询>  DROP VIEW <索引名>  注意:视图可以和基本表一样被查询,但是利用视图进行数据增,删,改操作,会受到一定的限制。  (1)由两个以上的基本表导出的视图(2)视图的字段来自字段表达式函数(3)视图定义中有嵌套查询(4)在一个不允许更新的视图上定义的视图

创建和管理视图

(创建视图时注意事项的介绍)  (一). 利用企业管理器创建与管理视图  1.使用企业管理器创建视图: 2.使用企业管理器的“向导”创建视图: 3.使用企业管理器的修改视图: 注意:在 “设计视图”时完成的工作: 添加表/删除表 ?添加引用字段/删除引用字段 ?调整字段顺序 ?设置分组 设置过滤条件 ?设置引用字段是否输出 ?设置视图其他属性 4.使用企业管理器的删除视图:  (二). 用T-SQL语句创建与管理视图  (查看由企业管理器创建的视图—“项目信息”其相应的T-SQL语句)(“视图属性”) 1. 使用CREATE VIEW创建视图的语法: 参见教材p130~135 例子1: 选择‘员工表’和‘项目表’中的部分字段和记录创建视图,并且限制表‘员工表’ 中的记录只能是部门为“项目部”的记录集合,视图定义为view_part,其程序清单如下:  CREATE VIEW view_part AS SELECT 员工表.编号, 员工表.姓名,员工表.性别,员工表.所属部门, 项目表.项目编号, 项目表.名称FROM 项目表 INNER JOIN 员工表 ON 项目表.负责人 = 员工表.编号WHERE 员工表.所属部门='项目部'  例子2:定义视图时指定别名并加密  CREATE VIEW 项目信息视图(项目名称,项目客户,项目负责人,开始日期,【计划工期(天)】) with encryption AS SELECT 项目表.名称,客户表.客户名称, 员工表.姓名,项目表.开始日期, DATEDIFF(day,项目表.开始日期,项目表.结束日期)FROM 项目表 INNER JOIN 员工表 ON 项目表.负责人 = 员工表.编号 INNER JOIN 客户表 ON 项目表.客户 = 客户表.客户编号 WHERE 员工表.所属部门='项目部'  使用语句:exec sp_helptext ‘项目信息视图’显示消息为:“对象备注已加密。”

视图应用的举例

例子5-3:使用WITH CHECK OPTION子句问题提出:若创建视图ygb_view,其程序清单如下:  CREATE VIEW ygb_view AS SELECT * FROM 员工表 WHERE 员工表.性别=‘女’执行下列语句,插入新记录:INSERT INTO ygb_view(姓名,性别,工资)values(‘李立三’,‘男’,2300)  插入操作成功,但不合理!解决办法:使用with check option,程序清单如下:  CREATE VIEW ygb_view AS SELECT * FROM 员工表 WHERE 员工表.性别=‘女’With check option  同样,插入新记录:INSERT INTO ygb_view(姓名,性别,工资) values(‘李立三’,‘男’,2300)插入操作将失败!  2.使用ALTER VIEW修改视图 语法:参见教材3.删除视图DROP VIEW 使用DROP VIEW命令删除视图的语法如下: DROP VIEW 视图名1 【, ……】例: DROP VIEW ygb_view

使用视图操作表数据

(一)、通过视图添加表数据  使用INSERT语句实现。 注意:视图是虚拟表,其本身不存储数据(来自其引用表), 添加的数据是存储于视图参照的数据表中。  条件分析:1)用户有向数据表插入数据的权限;2)视图只引用表中部分字段,插入数据时只能是明确其应用的字段取值;3)未引用的字段应具备下列条件之一: 允许空值;设有默认值;是标识字段;数据类型是timestamp或uniqueidentifer;4)视图不能包含多个字段的组合5)视图不能包含使用统计函数的结果;6)视图不能包含DISTINCT或GROUP BY子句;7)定义视图使用WITH CHECK OPTION,则插入数据应符合相应条件;8)若视图引用多个表,一条INSERT语句只能同一个基表表中数据;  例:首先创建了一个新的视图:  CREATE VIEW ygb_view AS SELECT * FROM 员工表 WHERE 员工表.性别=‘女’ with check option  然后,通过执行以下语句使用该视图向基表添加一条新的数据记录:INSERT INTO ygb_view(姓名,性别,工资) values(‘李立平’,‘女’,2300)  (二). 更新数据记录 使用视图可以更新基表数据记录(注意使用INSERT时的限制同样适用)。例子3:(1) update 项目_view set 项目负责人= ‘王大力’ where 项目负责人= ‘王立兵’(2) update 项目_view set 结束日期= DATEADD(day, 50, 结束日期) where 客户名称=‘CCH公司’  (三)、删除数据记录 利用DELETE语句,使用视图删除记录,可以删除任何基表中的记录。 注意: 必须指定在视图中定义过的字段来删除记录; 视图引用多个表时,无法用DELETE命令删除数据。例子4:delete ygb_view where 员工工资<1500

分享到:
评论

相关推荐

    Oracle 12C 数据字典视图概念深入浅出

    ### Oracle 12C 数据字典视图概念深入浅出 #### 一、概述 在Oracle 12C中引入了多租户容器数据库(CDB)的概念,它允许在一个容器数据库内创建多个可插拔数据库(PDB)。为了更好地管理这些数据库结构,Oracle 12C...

    oracle实验二视图

    本实验主要介绍了 Oracle 中的视图概念和操作。 一、什么是视图? 视图是一种虚拟表,基于一个或多个基本表,它们之间可以是一对一、多对一、多对多的关系。视图可以被当作一个独立的表来操作,但它的数据实际上...

    查询与视图.

    实验环境通常是在Windows XP操作系统上运行Visual FoxPro 6.0,这是早期常用的数据库开发工具,尽管现在可能已经被更现代的数据库管理系统如MySQL、SQL Server或Oracle取代,但基础的查询和视图概念在任何数据库系统...

    数据库实验报告(视图).pdf

    本实验报告主要介绍了数据库中的视图概念、基本特点、创建方法、数据查询、管理和维护等方面的知识点。 一、视图基本概念和特点 * 视图是对一个或多个基本表的查询语句的结果集,它本身并不保存数据,而是从基本表...

    sql Server 视图管理

    #### 一、视图概念与重要性 视图在SQL Server中扮演着至关重要的角色,它本质上是存储在数据库中的查询,提供了一种虚拟表的方式,允许用户从一个或多个表中选择数据。视图并不实际存储数据,而是保存了一个SQL查询...

    VC ++多视图切换

    **多视图概念** 多视图是指在单个应用程序窗口内,通过创建和管理多个视图控件(CView类的实例),来显示和操作不同的数据源或界面状态。每个视图都与特定的数据源关联,并且可以独立地更新和渲染数据。视图之间...

    (mysql面试题)MySQL中的视图的概念及其作用及代码展示.txt

    ### MySQL中的视图概念及其应用 #### 视图的基本概念 在MySQL中,视图(View)被定义为一种虚拟的表,它并不是一个物理存在的表,而是根据SQL语句的结果集来显示数据的一种方式。当用户通过视图查询数据时,实际上...

    TP5 视图和模板

    **一、视图概念** 视图是MVC(Model-View-Controller)架构中的“V”,主要负责展示数据。在TP5中,视图文件通常以`.html`或`.blade.php`为扩展名,它们存储在`application/views`目录下。视图文件不包含业务逻辑,...

    sanshitu.rar_三视图_可视图

    综上所述,"sanshitu.rar_三视图_可视图"不仅是对三视图概念的演示,更是一套集成了现代图形学技术的可视化工具。通过它,用户可以更加直观、更加生动地学习和理解三视图以及三维图形渲染的相关知识,从而提升个人在...

    2019_2020学年九年级数学下册第二十九章投影与视图29.2三视图第1课时三视图作业设计新版新人教版20200312396

    在实际教学中,教师通常会通过展示具体的几何体的三视图例子,让学生练习识别,以加深他们对三视图概念的理解。 紧接着,我们将学习如何正确绘制三视图。正确的三视图绘制不仅需要理解投影原理,还需要在绘图时保持...

    三视图课件

    #### 二、三视图概念 **三视图定义:** 为了完整地表达一个三维物体的空间形状,通常采用三个不同的视角来观察物体,得到三个方向上的正投影,这三种投影合称为“三视图”。 1. **主视图(正立面投影):** 从前向...

    mysql索引与视图的实例附答案宣贯.pdf

    视图概念: 视图是一种虚拟的表,是从数据库中一个或多个表中导出来的表。视图还可以从已经存在的视图的基础上定义。数据库中只存放了视图的定义,而没有存放视图的数据。这些数据存放在原来的表中。使用视图查询时...

    九年级数学下册第三十二章投影与视图32.2视图第1课时简单几何体的三视图学案无答案新版冀教版

    学习重点在于深入理解投影角度下的三视图概念,并能准确绘制简单几何体的三视图。难点在于实际操作中,正确把握各个视图的比例关系和位置,特别是对于初学者来说,可能在画图时容易出现比例失衡或位置错误。 综上所...

    《三视图》教案-04.pdf

    对于《三视图》这一数学教学内容而言,教案的设计尤为重要,它不仅需要帮助学生理解抽象的三视图概念,更要培养学生将理论知识应用于解决实际问题的能力。因此,一个精心设计的教案必须围绕教学目标,有效地组织教学...

    李海翔 - MySQL视图优化

    2. 逻辑层次要清晰,视图概念要明确,视图用途要清楚。 此外,视图优化技术的原理涉及对视图的SQL语句进行优化。这包括但不限于,选择合适的字段(尽量避免SELECT *)、使用索引优化查询、减少视图嵌套层数等。这些...

    【课课练】九年级数学下册 29.2.1 由几何体到三视图测试题(pdf) 新人教版.pdf

    在本节“九年级数学下册 29.2.1 由几何体到三视图”的学习中,我们将深入理解和掌握与三维几何图形相关的视图概念,这在工程、设计和数学问题解决中至关重要。以下是一些关键知识点: 1. **视图**:当我们从特定...

Global site tag (gtag.js) - Google Analytics