`

View的作用

阅读更多
这篇文章重要讲述下关于视图的作用:
一、视图的作用

       1.简单性。看到的就是需要的。视图不仅可以简化用户对数据的理解,也可以简化他们的操作。那些被经常使用的查询可以被定义为视图,从而使得用户不必为以后的操作每次指定全部的条件。

       2.安全性。通过视图用户只能查询和修改他们所能见到的数据。数据库中的其它数据则既看不见也取不到。数据库授权命令可以使每个用户对数据库的检索限制到特定的数据库对象上,但不能授权到数据库特定行和特定的列上。通过视图,用户可以被限制在数据的不同子集上:
       使用权限可被限制在基表的行的子集上。
       使用权限可被限制在基表的列的子集上。
       使用权限可被限制在基表的行和列的子集上。
       使用权限可被限制在多个基表的连接所限定的行上。
       使用权限可被限制在基表中的数据的统计汇总上。
       使用权限可被限制在另一视图的一个子集上,或是一些视图和基表合并后的子集上。

       3.逻辑数据独立性。视图可帮助用户屏蔽真实表结构变化带来的影响。

二、视图的优点

       (1)视图能简化用户的操作
       (2)视图机制可以使用户以不同的方式查询同一数据
       (3)视图对数据库重构提供了一定程度的逻辑独立性
       (4)视图可以对机密的数据提供安全保护

三、视图的安全性

       视图的安全性可以防止未授权用户查看特定的行或列,是用户只能看到表中特定行的方法如下:

       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: 选择‘员工表’和‘项目表’中的部分字段和记录创建视图,并且限制表‘员工表’ 中的记录只能是部门为“项目部”的记录集合,视图定义为V_ProjectPart,其程序清单如下:

CREATE VIEW V_ProjectPart
AS
SELECT 员工表.编号, 员工表.姓名,员工表.性别,
员工表.所属部门, 项目表.项目编号, 项目表.名称
FROM 项目表 INNER JOIN 员工表 ON 项目表.负责人 = 员工表.编号
WHERE 员工表.所属部门='项目部'

例子2:定义视图时指定别名并加密

CREATE VIEW 项目信息视图
(项目名称,项目客户,项目负责人,开始日期,[计划工期(天)])
with encryption
A
SELECT 项目表.名称,客户表.客户名称, 员工表.姓名,项目表.开始日期,
DATEDIFF(day,项目表.开始日期,项目表.结束日期)
FROM 项目表 INNER JOIN 员工表 ON 项目表.负责人 = 员工表.编号
INNER JOIN 客户表 ON 项目表.客户 = 客户表.客户编号
WHERE 员工表.所属部门='项目部'

使用语句:exec sp_helptext ‘项目信息视图’显示消息为:
“对象备注已加密。” 

例子3:使用WITH CHECK OPTION子句
问题提出:
若创建视图V_Employee,其程序清单如下:

CREATE VIEW V_Employee
AS
SELECT * FROM 员工表
WHERE 员工表.性别=‘女’执行下列语句,插入新记录:
INSERT INTO V_Employee(姓名,性别,工资)
values(‘李立三’,‘男’,2300)


插入操作成功,但不合理!
解决办法:使用with check option,程序清单如下:

CREATE VIEW V_Employee
AS
SELECT * FROM 员工表 WHERE 员工表.性别=‘女’With check option

同样,插入新记录:
INSERT INTO V_Employee(姓名,性别,工资) values(‘李立三’,‘男’,2300)
插入操作将失败!

2.使用ALTER VIEW修改视图
3.删除视图DROP VIEW
  使用DROP VIEW命令删除视图的语法如下: DROP VIEW 视图名1 [, ……]
例: DROP VIEW V_Employee

七、使用视图操作表数据
(一)、通过视图添加表数据
  使用INSERT语句实现。
 注意:视图是虚拟表,其本身不存储数据(来自其引用表), 添加的数据是存储于视图参照的数据表中。

条件分析:
1)用户有向数据表插入数据的权限;
2)视图只引用表中部分字段,插入数据时只能是明确其应用的字段取值;
3)未引用的字段应具备下列条件之一:
  允许空值;设有默认值;是标识字段;数据类型是timestamp或uniqueidentifer;
4)视图不能包含多个字段的组合
5)视图不能包含使用统计函数的结果;
6)视图不能包含DISTINCT或GROUP BY子句;
7)定义视图使用WITH CHECK OPTION,则插入数据应符合相应条件;
8)若视图引用多个表,一条INSERT语句只能同一个基表表中数据;

例:
首先创建了一个新的视图:

CREATE VIEW V_Employee
AS
SELECT * FROM 员工表 WHERE 员工表.性别=‘女’ with check option
然后,通过执行以下语句使用该视图向基表添加一条新的数据记录:
INSERT INTO V_Employee(姓名,性别,工资) values(‘李立平’,‘女’,2300)

(二). 更新数据记录
使用视图可以更新基表数据记录(注意使用INSERT时的限制同样适用)。
例子4:
(1) update 项目_view
  set 项目负责人= ‘王大力’ where 项目负责人= ‘王立兵’
(2) update 项目_view
  set 结束日期= DATEADD(day, 50, 结束日期) where 客户名称=‘CCH公司’

(三)、删除数据记录
  利用DELETE语句,使用视图删除记录,可以删除任何基表中的记录。
  注意: 必须指定在视图中定义过的字段来删除记录;
     视图引用多个表时,无法用DELETE命令删除数据。
例子5:delete V_Employee where 员工工资<1500
分享到:
评论

相关推荐

    android-pullView

    android-pullView

    DebugView_Tool

    DebugView作用: 在debug版的exe直接运行的时候,DebugView.exe可以获取调试信息; DebugView可以将显示的信息保存问log文件; 还有其它的功能,可以查看帮助文档;

    HexView2.rar_HexView2_hex_hexview_二进制文件_十六进制 查看

    总的来说,HexView2是一款不可或缺的二进制文件查看工具,无论是在日常开发工作还是在特定的项目需求中,都能发挥其独特的作用。通过其强大的十六进制查看功能,用户可以深入探索二进制文件的底层细节,从而更好地...

    HexView,hex等格式文件查看工具

    标题中的“HexView”是一款由Vector公司开发的专业文件查看工具,尤其适用于查看和处理十六进制(hex)格式的文件。...其丰富的功能,如批处理支持和多种文件格式处理,使得它在各种工作场景下都能发挥重要作用。

    DebugView中文版

    它不仅简化了调试过程,提高了开发效率,还提供了丰富的定制选项,可以根据个人需求调整和过滤调试信息,对于提升软件质量及优化代码有着显著作用。通过深入理解和熟练运用DebugView,开发者能更好地驾驭复杂的编程...

    jsonview for chrome ,json view插件

    这就是JSONView插件的作用所在。 JSONView插件的主要功能包括: 1. **自动格式化**:当访问一个返回JSON数据的URL时,JSONView会自动将原始的JSON文本转换成易于阅读的树状结构,每个键值对都清晰地显示出来,使...

    asn1view工具

    总之,asn1view是一个强大的工具,它为IT专业人士提供了一种便捷的方式来检查和理解ASN.1编码的数据,无论是在开发、测试还是故障排查的过程中,都能发挥重要作用。对于涉及ASN.1编码的项目,掌握asn1view的使用将极...

    C++View C++View C++View

    《C++View》是一本深入探讨C++编程语言的经典图书,其内容涵盖了C++的核心概念、语法特性以及高级编程技术。书中的每一个观点都旨在帮助读者深入理解C++的本质,从而提升编程技能和效率。在C++这个标签下,我们可以...

    qlikview 超值资料

    qlikview 超值资料包含了BI(商业智能)、ETL(提取、转换、加载)以及REPORT(报表)的相关知识,这些是数据处理...通过深入学习和实践这些知识点,可以提升在数据驱动决策中的能力,并在商业智能项目中发挥重要作用。

    qlikview9.0开发手册

    - **服务器模式**:介绍了QlikView Server的功能及其在企业级部署中的作用。 - **发布机制**:QlikView Publisher负责将QlikView应用程序自动发布到指定的目标位置,便于用户访问和使用。 #### 五、数据与脚本入门 ...

    HDFView-3.1.0-win10vs14_64.zip

    标题中的“HDFView-3.1.0-win10vs14_64.zip”指的是一款适用于Windows 10且与Visual Studio 2015兼容的HDFView...因此,HDFView是处理Keras模型文件的重要辅助工具,尤其在模型的保存、分享和复现过程中起到关键作用。

    android 自定义View界面大合集

    2. **绘图基础**:`Canvas`和`Paint`对象在自定义View中起到核心作用。`Canvas`提供了绘图操作接口,如绘制线条、形状、文本和位图,而`Paint`则控制颜色、样式、字体等绘图属性。熟悉`Matrix`变换和`Shader`着色器...

    traceview_tool_lib.zip

    `traceview.bat`是Windows操作系统下的批处理文件,它的作用是启动`Traceview`工具。当你双击这个文件,它会调用相应的Java命令来运行`Traceview`,通常这个命令会包含`java -jar traceview.jar`这样的参数。 `lib`...

    jsonview使用工具

    2. 插件不起作用:检查是否已启用插件,或者更新到最新版本,有时浏览器更新可能导致插件兼容性问题。 3. 数据加载慢:如果JSON数据量大,可能需要一段时间来渲染,耐心等待即可。 总结来说,JSONView是Chrome...

    Vmware_View虚拟桌面

    同时,配置DHCP服务器,指定作用域地址为172.30.5.210~172.30.5.249。 2. **部署View Connection Server虚拟机**:使用vSphere Client登录到vCenter Server,在第一台vSphere Server中,从现有的Windows Server ...

    TCPView.zip

    综上所述,TCPView是一个强大的网络监控工具,对于了解和管理系统的网络连接有着重要作用。无论是普通用户还是IT专业人士,都能从中受益。通过深入理解和有效利用TCPView,我们可以更好地理解网络连接的动态,提高...

    自定义view-画板

    这个组件由三个自定义View构成,每个View都有其特定的功能和作用。 首先,我们来看第一个自定义View,它通常作为画布(Canvas)存在。在Android中,Canvas是进行绘图操作的基础,它提供了各种绘图方法,如drawLine...

    Android View api 详解1

    本篇文章将深入探讨`getLeft()`、`getLocationInWindow()`以及`getLocationOnScreen()`这三个方法,它们在理解View的位置信息上起着至关重要的作用。 1. `getLeft()`: 这个方法返回View左边缘距离其父View左边缘的...

    View页面掀起的效果DEMO,镜面显示背面View内容

    这个DEMO不仅具有趣味性,而且在实际应用中,如电子书阅读器、卡片式设计的界面等,都能发挥重要作用。 首先,我们要理解这个效果的核心技术是视图动画(View Animation)。在Android中,视图动画主要分为两种类型...

    Power View——卡片.pdf

    Power View是Microsoft Excel 2016中的一个强大数据可视化工具,它允许用户通过交互式报告来探索和呈现数据。在这个特定的场景中,我们将关注如何使用Power View创建卡片报表,这是一种有效展示分类数据的方法,尤其...

Global site tag (gtag.js) - Google Analytics