视图的创建和使用.ppt
第8章 视图的创建和使用 视图是一种常用的数据库对象 视图是从一个或者多个表或视图中导出的表,其结构和数据是建立在对表的查询基础上的,为视图提供数据的表称为基表 视图不是真实存在的基础表而是一个虚拟表,它是引用存储在数据库中的查询语句动态创建的8.1 概述8.2 使用视图的优点和作用 (1)可以使视图集中数据、简化和定制不同用户对数据库的不同数据要求 (2)使用视图可以屏蔽数据的复杂性,用户不必了解数据库的结构,就可以方便地使用和管理数据 (3)视图可以定制不同用户对数据的访问权限,让不同的用户以不同的方式看到不同或者相同的数据集 (4)可以使用视图重新组织数据 视图与表的异同 相同:都是由一些记录和字段组成的二维表 区别:视图不存储数据,真正的数据依然存储在数据表中8.3 创建视图创建视图时应该注意以下情况:1、如果视图引用的基表或者视图被删除,则该视图不能再被使用,直到创建新的基表或者视图 2、如果视图中某一列是函数、数学表达式、常量或者来自多个表的列名相同,则必须为列定义名称 3、当通过视图查询数据时,SQL Server要检查以确保语句中涉及的所有数据库对象存在,而且数据修改语句不能违反数据完整性规则 4、视图的名称对每个用户必须是唯一的。此外,该名称不得与该用户拥有的任何表的名称相同8.3 创建视图1、使用向导创建视图2、使用企业管理器创建视图3、使用CREATE VIEW命令创建视图 1、使用CREATE VIEW语句创建视图 格式为:CREATE VIEW view_name(column,n)AS select_statement8.3 创建视图3、使用CREATE VIEW命令创建视图 创建一视图,要求该视图返回结果集中包含:员工表的姓名、性别、所属部门,项目表的名称、开始日期CREATE VIEW project_viewASSELECT e.姓名,e.性别,e.所属部门,p.名称,p.开始日期FROM 员工数据表 as e INNER JOIN 项目数据表 as pON e.编号=p.负责人EXEC sp_helptext project_view8.4 使用视图可使用企业管理器和查询分析器对视图进行操作1、通过视图查询数据(企业管理器 查询分析器)格式:SELECT FROM WHERE 8.4 使用视图2、通过视图添加数据(企业管理器 查询分析器)格式:INSERT INTO(字段列表)VALUES(列值)例:用视图的方式向员工数据表中插入一条记录 INSERT INTO employee_view VALUES(15,程琳,女,办公室,2500)注意:通过视图向基表插入记录时,不能同时向多个基表插入记录8.4 使用视图3、通过视图更改数据(企业管理器 查询分析器)格式:UPDATE SET=,WHERE 例:用视图的方式对员工数据表中的记录进行修改 UPDATE employee_view SET 姓名=程玲 WHERE 姓名=程琳注意:通过视图向基表修改记录时,不能同时向多个基表修改记录8.4 使用视图4、通过视图删除数据(企业管理器 查询分析器)格式:DELETE WHERE 注意:通过视图向基表删除记录时,不能同时向多个基表删除记录8.5 视图的维护1、修改视图 (1)使用企业管理器修改视图 视图更名、修改视图、删除视图 (2)使用ALTER VIEW语句修改视图 格式为:ALTER VIEW view_name(column,n)AS select_statement例如:使用CREATE VIEW创建视图employee_view,包括员工数据表中的所有男员工的所有记录,使用Alter view修改视图,a、只留下字段“姓名”和“工资”,去掉其它字段 b、为字段“姓名”和“工资”加上字段别名,即“男员工姓名”和“员工工资”8.5 视图的维护1、修改视图 create view employee_view as select*from 员工数据表 where 性别=男 GO alter view employee_view(男员工姓名,员工工资)as select 姓名,工资 from 员工数据表 where 性别=男8.5 视图的维护2、删除视图 可以使用DROP VIEW从数据库中删除一个或多个视图 格式:DROP VIEW view_name,n1、修改视图 (3)使用系统存储过程sp_rename修改视图名 格式:sp_rename old_name,new_name