实验05 视图的创建和使用

合集下载

视图的使用---实验报告5

视图的使用---实验报告5
as
select学生档案.学号,姓名,性别,专业,班级,学生成绩表.课程ID,总成绩
from学生档案,学生成绩表
where学生档案.学号=学生成绩表.学号and学生档案.学号in(
select学号
from学生成绩表
where总成绩>=85)
运行结果如图所示:
五、教师评语பைடு நூலகம்
set课程名称='逻辑学'
where课程ID='RX0002'
运行结果如图所示:
6_4_10视图的删除
drop view管理学课程信息简表
运行结果如图所示:
6_4_11使用“企业管理器”创建视图
运行结果如图所示:
四、出现的问题及解决方案
在基于多张表嵌套查询的视图中,要对“学生成绩优秀表”进行查询,按书本上代码进行查询时出错,代码为:
6_4_4基于多张表连接的视图
create view学生课程成绩表
as
select学生档案.学号,姓名,性别,专业,班级,学生成绩表.课程ID,总成绩
from学生档案,学生成绩表
where学生档案.学号=学生成绩表.学号
运行结果如图所示:
6_4_5基于多张表嵌套查询的视图
create view学生成绩优秀表
as
select学生档案.学号,姓名,性别,专业,班级,学生成绩表.课程ID,总成绩
from学生档案,学生成绩表
where学生档案.学号in(
select学号
from学生成绩表
where总成绩>=85)
运行结果如图所示:
6_4_6含有虚字段的视图
create view学生期末平均成绩表

数据库实验五:视图的应用

数据库实验五:视图的应用

数据库实验五:视图的应用数据库实验五:视图的应用一、实验目的与要求:1.实验目的(1)理解视图的概念;(2)掌握视图的使用方法。

(3)理解视图和基本表的异同之处。

2.实验要求(1)参照实验五中完成的查询,按如下要求设计和建立视图:1)基于单个表按投影操作定义视图。

2)基于单个表按选择操作定义视图。

3)基于单个表按选择和投影操作定义视图。

4)基于多个表根据连接操作定义视图。

5)基于多个表根据嵌套操作定义视图。

6)定义含有虚字段的视图。

(2)分别在定义的视图设计一些查询(包括基于视图和基本表的连接或嵌套查询)。

(3)在定义的视图上进行插入、更新和删除操作,分情况讨论哪些操作可以成功完成,哪些操作不能完成,并分析原因。

(4)在实验报告中要给出具体的视图定义要求和操作要求,并针对各种情况做出具体的分析和讨论。

二、实验内容1、实验原理(1)视图是用SQL SELECT查询定义的,创建视图命令格式如下:CREATE VIEW <视图名> AS(2)删除视图的命令格式如下:DROP VIEW <视图名>2、实验步骤与结果(1)调出SQL Server2005软件的用户界面,进入SQL SERVERMANAGEMENTSTUDIO。

(2)输入自己编好的程序。

(3)检查已输入的程序正确与否。

(4)运行程序,并分析运行结果是否合理和正确。

在运行时要注意当输入不同的数据时所得到的结果是否正确。

(5)输出程序清单和运行结果。

(1)参照实验五中完成的查询,按如下要求设计和建立视图:1)基于单个表按投影操作定义视图。

create view v asselect教师编号,姓名from教师2)基于单个表按选择操作定义视图。

create view v_order asselect*from教师where职称='教授'3)基于单个表按选择和投影操作定义视图。

create view v_cuss asselect教师编号,姓名,职称from教师where职称='教授'4)基于多个表根据连接操作定义视图。

数据库实验5 视图操作

数据库实验5 视图操作

实验五视图操作(2学时)【实验目的】1. 学会使用SQL语句创建和使用视图,加深对视图和SQL Server基表作用的理解。

2. 了解数据库安全控制的机制,以及自主存取控制方法。

【实验要求】1.掌握创建、修改视图的SQL语句的用法。

2.掌握使用企业管管理器创建、修改视图的方法。

3.掌握查看视图的系统存储过程的用法。

4.掌握视图的使用方法。

5.掌握SQL有关用户、角色及操作权限的管理方法。

【实验内容】一、视图操作(一)定义视图以Student 、Course表为基础完成以下视图定义。

1.定义计算机系学生基本情况视图V_Computer。

2.将Student Course 和Student_course表中学生的学号,姓名,课程号,课程名,成绩定义为视图V_S_C_G。

3.将各系学生人数,平均年龄定义为视图V_NUM_AVG。

4.定义一个反映学生出生年份的视图V_YEAR。

5.将各位学生选修课程的门数及平均成绩定义为视图V_A VG_S_G。

6.将各门课程的选修人数及平均成绩定义为视图V_A VG_C_G。

(二)使用视图1. 查询以上所建的视图结果。

2. 查询平均成绩为90分以上的学生学号、姓名和成绩。

3. 查询各课成绩均大于平均成绩的学生学号、姓名、课程和成绩。

4. 按系统计各系平均成绩在80分以上的人数,结果按降序排列。

(三)修改视图1. 通过视图V_IS,分别将学号为“S1”和“S4”的学生姓名更改为“S1_MMM”,”S4_MMM” 并查询结果。

2. 通过视图V_IS,新增加一个学生记录('S12','YAN XI',19,'IS'),并查询结果。

3. 通过视图V_IS,新增加一个学生记录('S13','YAN XI',19,'MA'),并查询结果。

4. 通过视图V_IS,删除学号为“S12”和“S3”的学生信息,并查询结果。

实验五__视图的创建与使用

实验五__视图的创建与使用

视图的创建与使用一、实验目的(1)理解视图的概念。

(2)掌握创建视图、测试、加密视图的方法。

(3)掌握更改视图的方法。

(4)掌握用视图管理数据的方法。

二、实验内容1.创建视图(1)创建一个名为stuview2的水平视图,从数据库Student_info的Student表中查询出性别为“男”的所有学生的资料。

并在创建视图时使用with check option。

(注:该子句用于强制视图上执行的所有修改语句必须符合由Select语句where中的条件。

)create view stuview2asselect*from Studentwhere Sex='男'with check option查看视图:select*from stuview2(2)创建一个名为stuview3的投影视图,从数据库Student_info的Course表中查询学分大于3的所有课程的课程号、课程名、总学时。

并在创建时对该视图加密。

(提示:用with ENCRYPTION关键子句)create view stuview3with ENCRYPTIONasselect Cno,Cname,Total_perior from Coursewhere Credit>3查看视图:select*from stuview3(3)创建一个名为stuview4的视图,能检索出“051”班所有女生的学号、课程号及相应的成绩。

create view stuview4asselect*from SCwhere Sno=(select Sno from Studentwhere Classno='051'and Sex='女')查看视图:select*from stuview4(4)创建一个名为stuview5的视图,能检索出每位选课学生的学号、姓名、总成绩。

create view stuview5asselect Student.Sno学号,Sname姓名,Grade成绩from Student,SCwhere Student.Sno=SC.Sno查看视图:select*from stuview5若出现如上图所示情况,单击“查询”→IntelliSense→刷新本地缓存然后就解决了。

第5章_视图的创建与使用

第5章_视图的创建与使用

5.2.2使用Transact-SQL语句创建视图 .2.2使用Transact-SQL语句创建视图 使用Transact
使用Transact SQL语言中的 使用 Transact-SQL 语言中的 CREATE VIEW 语 Transact语言中的CREATE VIEW语 句创建视图,其语法形式如下: 句创建视图,其语法形式如下: CREATE VIEW [ schema_name . ] view_name [ (column [ ,...n ] ) ] ...n [ WITH ENCRYPTION ] AS select_statement [ WITH CHECK OPTION ] [ ; ]
5.1.2 视图的优点
简化数据操作:视图可以简化用户处理数据的方式。 简化数据操作:视图可以简化用户处理数据的方式。 着重于特定数据: 着重于特定数据:不必要的数据或敏感数据可以不出 现在视图中。 现在视图中。 视图提供了一个简单而有效的安全机制, 视图提供了一个简单而有效的安全机制,可以定制不 同用户对数据的访问权限。 同用户对数据的访问权限。 提供向后兼容性: 提供向后兼容性:视图使用户能够在表的架构更改时 为表创建向后兼容接口。 为表创建向后兼容接口。 自定义数据:视图允许用户以不同方式查看数据。 自定义数据:视图允许用户以不同方式查看数据。 导出和导入数据: 导出和导入数据:可使用视图将数据导出到其他应用 程序。 程序。
CHECK OPTION :强制针对视图执行的所有 数据修改语句都必须符合在 select_statement 中设置的条件。 中设置的条件。 ENCRYPTION:对视图文本进行加密。 ENCRYPTION:对视图文本进行加密。
例2 建立一个只包括教师号、姓名和年龄的 建立一个只包括教师号、 视图TeacherView TeacherView。 视图TeacherView。 CREATE VIEW TeacherView AS SELECT tno,tname,tage FROM teachers

实验5-视图

实验5-视图

实验五视图1实验目的(1)掌握SQL视图语句的基本使用方法,如CREATE VIEW、DROP VIEW。

(2)掌握视图更新、WITH CHECK OPTION等高级功能的使用。

2实验内容2.1 掌握SQL视图语句的基本使用方法(1)创建视图(省略视图列名)。

(2)创建视图(不能省略列名的情况)。

(3)删除视图(RESTRICT / CASCADE)。

2.2 掌握视图更新和WITH CHECK OPTION的高级使用方法(1)创建视图(WITH CHECK OPTION),并利用INSERT、DELETE和UPDATE语句加以验证。

(2)创建一个行列子集可更新视图,并利用INSERT、DELETE和UPDATE语句加以验证。

(3)创建一个不可能更新的视图,并利用更新语句验证该视图不可更新。

3实验要求(1)深入复习教材第三章SQL有关视图语句。

(2)根据书上的例子,针对TPCH数据库模式设计各种视图语句,每种类型视图语句至少要设计一个,描述清楚视图要求,运行你所设计的视图语句,并截图相应的实验结果,每幅截图并要有较为详细的描述。

也可以按照附1所列示例做实验。

(3)实验步骤和实验总结中要详细描述实验过程中出现的问题、原因和解决方法。

(4)思考题:KingbaseES把视图的定义存储在那个系统表中?如何查看某个视图的定义?4实验步骤4.1 掌握SQL视图语句的基本使用方法(1)创建视图(省略视图列名)。

(2)创建视图(不能省略列名的情况)。

(3)删除视图(RESTRICT / CASCADE)。

4.2 掌握视图更新和WITH CHECK OPTION的高级使用方法(4)创建一个行列子集可更新视图,并利用INSERT、DELETE和UPDATE语句加以验证。

(5)创建视图(WITH CHECK OPTION),并利用INSERT、DELETE和UPDATE语句加以验证。

(6)创建一个不可能更新的视图,并利用更新语句验证该视图不可更新。

数据库实验——视图的创建与使用

数据库实验——视图的创建与使用

数据库实验——视图的创建与使用数据库是一种利用计算机系统来管理、存储、处理数据的技术,视图则是在数据库中使用的一种技术。

视图是一种虚拟表,实际上并不存储数据,而是使用查询语句从一个或多个表中提取所需的数据。

在本次实验中,将学习视图的创建和使用。

一、实验目的1. 理解视图的概念和特点;2. 掌握视图的创建和使用方法;3. 熟悉视图的应用场景。

二、实验内容1. 视图的创建方法;2. 视图的使用方法;3. 视图的实际应用。

三、实验过程1. 视图的创建方法视图的创建方法如下:CREATE VIEW [视图名称] AS [查询语句];例如,要从学生表中提取所有学生的姓名和学号,则可以使用以下语句创建视图:CREATE VIEW student_info AS SELECT sname, sno FROM student;这样,就创建了一个名为student_info的视图,其中包含学生表中的姓名和学号两列数据。

2. 视图的使用方法创建视图之后,可以像使用普通表一样使用视图。

例如,可以使用SELECT语句来查询视图中的数据,如下所示:SELECT * FROM student_info;这样就可以查询出student_info视图中的所有数据。

3. 视图的实际应用视图在实际应用中有很多用途,例如:(1)简化查询语句当数据库中有较多的关联表时,查询语句会变得非常复杂。

此时,可以使用视图来简化查询语句。

例如,以下语句查询学生所在的班级名称:SELECT s.sname, ame FROM student s INNER JOIN class c ON s.classno = c.classno;使用视图后,查询语句可以变得更简洁:CREATE VIEW student_class AS SELECT s.sname, ame FROM student s INNER JOIN class c ON s.classno = c.classno;SELECT * FROM student_class;(2)保护数据安全例如,可以创建只包含学生姓名和学号的视图,而不包含其他敏感数据,以确保保护学生的隐私。

数据库实验——视图的创建与使用

数据库实验——视图的创建与使用

数据库原理与应用实验报告题目:视图的创建与使用学号:_________________姓名:_________________ 教师:_________________实验题目视图的创建与使用1、实验内容视图的创建与使用2、实验目的与要求1、理解视图的概念。

2、掌握视图创建的方法。

3、掌握更改视图的方法。

3、实验环境已安装SQL Server 2008 企业版的计算机;具有局域网环境,有固定IP;4、实验结果与分析1创建教材的三个数据表Student、Course及SC。

CREATE TABLE Student(Sno CHAR(9),Sname CHAR(20),Ssex CHAR(20),Sage SMALLINT,Sdept CHAR(20));CREATE TABLE SC(Sno CHAR(9),Cno CHAR(4),Grade SMALLINT,);CREATE TABLE Course(Cno CHAR(4),Cname CHAR(40),Cpno CHAR(4),Ccredit SMALLINT,);2向三个表中插入教材中的数据。

INSERT INTO Student values(‘200215121’,’李勇’,’男’,20,’CS’); INSERT INTO Student values(‘200215122’,’刘晨’,’女’,19,’CS’);INSERT INTO Student values(‘200215121’,’王敏’,’女’,18,’MA’);INSERT INTO Student values(‘200215121’,’张立’,’男’,19,’IS’);INSERT INTO Course values(‘1’,’数据库’,’5’,4);INSERT INTO Course(Cno,Cname,Credit) values(‘2’,’数学’,2);INSERT INTO Course values(‘3’,’信息系统’,’1’,4);INSERT INTO Course values(‘4’,’操作系统’,’6’,3);INSERT INTO Course values(‘5’,’数据结构’,’7’,4);INSERT INTO Course (Cno,Cname,Credit) values(‘6’,’数据处理’,2);INSERT INTO Course values(‘7’,’PASCAL语言’,’6’,4);INSERT INTO SC V ALUES (‘200215121’, ‘1’, 92);INSERT INTO SC V ALUES (‘200215121’, ‘2’, 85);INSERT INTO SC V ALUES (‘200215121’, ‘3’, 88);INSERT INTO SC V ALUES (‘200215122’, ‘2’, 90);INSERT INTO SC V ALUES (‘200215122’, ‘3’, 80);3、创建一个名为View_Male_Student的视图,从表Student中查询出性别为男的所有学生的资料。

实验5 视图的创建与使用分析

实验5 视图的创建与使用分析

XX实验报告学号 :系别专业班级姓名课程名称课程类型学时数实验名称视图的创建和使用实验目的:使用SQL Server Mangement Studio创建视图。

使用Transcat-sql创建视图。

查询视图了解创建和查询视图的方法。

实验要求:据库设计确定要创建的视图。

之前已经完成了其他实验,成功创建了stu中的各个表。

了解创建和查询视图的方法实验内容:要点:视图是从一个表或者几个基本表导出的表。

他与基本表不同,是一个虚表。

数据库只存放视图的定义,而不存放对应的数据,这些数据仍然存放在原来的基本表中,所以一旦基本表的数据发生改变,先从视图中查出的信息也就发生改变,从这个意义上来讲,视图就像一个窗口。

视图一经定义,就可以和基本表一样被查询,被删除,也可以在一个视图上在定义另一个视图,但对视图的(增,删,改)操作有一定的限制。

1. 打开SQL Server2008 ->SQL Server Mangenent Studio命令,弹出连接到服务器的对话框。

2. 在“连接到服务器”的对话框中,单击”连接“按钮。

3. 在“对象资源管理器中”依次展开“数据库“,stu,和视图。

4. 右击视图,然后选择”新建视图“的命令。

5. 在”添加表“对话框中选择student(students)表中的sno,sname,ssex,sage,sdept。

6.sdept的输出选项不可选,在筛选器一栏输入”is“,具体设置如图所示。

7. 将视图的架构属性设置为students。

8. 选择文件进行保存,输入名称”StudentISView“,然后单击确定。

实验结果:视图的创建:建立信息系学生的视图,并要求进行修改和插入操作认保持该视图只有信息系的学生:信息系学生的视图进行更新操作:更新操作后将姓名改变为‘刘晨’,如图所示:对新建的S_G视图进行删除操作;如图所示:将删除在视图中学号为201315127的学生信息。

对新建的F_Student视图进行查询操作:即选择F_Student视图中姓名为:宋敏的同学所有的信息如图所示:实验总结:通过本次实验对SQL-Server语言有了更深入的理解,并且掌握了使用SQL Server Mangement Studio创建视图。

数据库实验---视图的定义和操作

数据库实验---视图的定义和操作

实验视图的定义和操作一、实验目的本次实验了解SQL Server 2005 的启动,熟悉如何使用SSMS 和SQL 建立数据库和表,并加深对于完整性的理解。

...二、背景知识在使用数据库的过程中,接触最多的就是数据库中的表。

表是数据存储的地方,是数据库中最重要的部分,管理好表也就管理好了数据库。

表是由行和列组成的。

创建表的过程主要就是定义表的列的过程。

表的列名在同一个表中具有唯一性,同一列的数据属于同一种数据类型。

除了用列名和数据类型来指定列的属性外,还可以定义其它属性:是否为空、默认值、标识符列、全局唯一标识符列等。

约束是SQL Server 提供的自动保持数据库完整性的一种方法,定义了可输入表或表的单个列中的数据的限制条件。

在SQL Server 中有5 种约束:主关键字约束(Primary Key Constraint)、外关键字约束(Foreign Key Constraint)、惟一性约束(Unique Constraint)、检查约束(Check Constraint)和默认约束(Default Constraint)。

...三、实验内容1.对应HRM 数据库,参照前面实验中完成的查询,按如下要求自行设计视图:1)基于单个表按投影操作定义视图。

举例:定义一个视图用以查看所有员工的编号、姓名和出生日期。

2)基于单个表按选择操作定义视图。

举例:定义一个满足sex=’true’的员工的所有信息的视图。

3)基于单个表按选择和投影操作定义视图。

举例:定义一个视图用以查看部门号码为‘2’的所有员工的姓名、电话和邮件地址。

4)基于多个表根据连接操作定义视图。

举例:定义一个视图用以查看所有员工的姓名、部门名及工资。

5)基于多个表根据嵌套查询定义视图。

举例:定义一个比所有财务部的雇员工资都高的雇员的信息的视图6)定义含有虚字段(即基本表中原本不存在的字段)的视图。

举例:定义一个视图用以查看所有雇员的编号、姓名、年龄。

实验五视图的创建和使用

实验五视图的创建和使用

实验五视图的创立和使用5.1概述5.1.1任务一理解视图的概念视图是一个虚拟表,其内容由查询定义。

同真实的表一样,视图包含一系列带有名称的列和行数据。

但是,视图并不在数据库中以存储的数据集合形式存在。

行和列数据来自由定义视图的查询所引用的表,并且在引用视图时动态生成。

对其中所引用的基表来说,视图的作用类似于挑选。

定义视图的挑选可以来自当前或其他数据库的一个或多个表,或者其他视图。

视图被定义后便存放在数据库中,对视图中的数据的操作与对表的操作一样,可以对其进展查询、修改和删除,但对数据的操作要满足一定的条件。

当对视图所看到的数据进展修改时,相应的基表的数据也会发生变化,同时,假设基表的数据发生变化,这种变化也会自动地反映到视图中。

5.1.2任务二理解视图的优点用户可以根据自己的实际需要创立视图,使用视图有很多优点,主要有以下几点:1、简单性视图可以屏蔽数据的复杂性,简化用户对数据库的操作。

使用视图,用户可以不必理解数据库的构造,就可以方便地使用和管理数据。

那些被经常使用的查询可以被定义为视图,从而使得用户不必为以后的操作每次指定全部的条件。

2、逻辑数据独立性视图可以使应用程序和数据库表在一定程度上独立。

假设没有视图,应用一定是建立在表上的。

有了视图之后,程序可以建立在视图之上,从而程序与数据库表被视图分割开来。

3、平安性通过视图用户只能查询和修改他们所能见到的数据。

数据库中的其他数据那么既看不见也取不到。

5.2创立视图创立视图的方法有三种:在创立视图前请考虑如下原那么:➢只能在当前数据库中创立视图.➢视图名称必须遵循标识符的规那么,且对每个用户必须为唯一.此外,该名称不得与该用户拥有的任何表的名称一样.➢可在其他视图和引用视图的过程之上建立视图.SQLServer 2000允许嵌套多达32级视图➢假设要创立视图,数据库所有者必须授予用户创立视图的权限,并且用户对视图定义中所引用的表或视图要有适当的权限5.2.1任务一使用企业管理器创立视图使用企业管理器创立视图的详细操作步骤如下:1、翻开企业管理器窗口,翻开“新建视图〞对话框。

实验五:视图的创建与使用

实验五:视图的创建与使用
理解索引和视图的特点,并掌握创建和删除索引的方 法和视图的查询
1、 建立索引 1. 选择要创建索引的数据库文件夹, 如“S_C”文件夹,并在右边的对象窗口中选 择并打开其中的“表”对象。 2. 选择所要创建索引的表,如“Student”表, 并从“操作”菜单中选择“所有任务”子菜单 下的“管理索引”命令,打开SQL Server 的 索引管理器窗口。 3. 单击其中的“新建”按钮,创建新的索引,并 为其设置相应的属性。 4. 为Student 表创建一个基于“Sname”列 和“Sdept”列的索引IX_Student,其中 Sname列按升序排列,Sdept列按降序排列。
后单击“确定”按钮,关闭视图设计窗口,完成视图
的创建。
7) 创建一个简单视图,统计每门课程的选课人数和最高
分。
实验结
果(结 论及
成功建立了试验所要求的视图
分析)
教师
评语
2、 建立视图并利用视图查询数据 1) 启动SQL Server企业管理器,打开“SQL Server
Enterprise Manager”窗口。 2) 选择要创建视图的数据库文件夹,如“S_C”文件
夹,并在右边的对象窗口中选择其中的“视令,打开SQL Server的视图设计窗口。 4) 在“数据源关系图窗口”中单击鼠标右键,打开“添 加表”窗口,添加XSQK表和Student表。 5) 选择Student表的学号和姓名列,选择Student表的 sno,sname和ssex列,作为视图的显示列。
指导教师 黄川林
实验室 G108
实验日期
分组 情况
何威、李苗苗、杨德龙、孟炜 东、杨琦


1、 建立索引 1. 选择要创建索引的数据库文件夹, 如“S_C”文件夹,并在右边的对象窗口中选 择并打开其中的“表”对象。 2. 选择所要创建索引的表,如“Student”表, 并从“操作”菜单中选择“所有任务”子菜单 下的“管理索引”命令,打开SQL Server 的 索引管理器窗口。 3. 单击其中的“新建”按钮,创建新的索引,并 为其设置相应的属性。 4. 为Student 表创建一个基于“Sname”列 和“Sdept”列的索引IX_Student,其中 Sname列按升序排列,Sdept列按降序排列。

视图的创建和使用实验报告

视图的创建和使用实验报告

经过这次数据库系统基础课程设计我们不仅及时巩固的了数据库以及软件工程的知识并对数据库以及软件工程提供的开发流程和工具对于实现特定功能程序的重要意义签名某某某2011评语与成绩
测试过程: (实验中出现的问题、错误、解决方法) 建立视图的时候发现不会使用 SQL 语句建立,就只能直接建立了,但建 专业: 立过程中条件控制不得当,导致视图建立出错,后来在同学的帮助下成功建 立视图。 实验名称 实验类型
软件实验报告
软件工程 课程: 数据库
学号: 1234567890 姓名: 某某某 班级: 10 软件工程 视图的创建和使用 验证性 实验时间 2011 年 12 月 27 日
实验环境
Microsoft SQL Server 2005
实验目的与要求: 1.理解 SQL 的视图以及与基本表的区别; 实验总结: 2.掌握 SQL 视图的定义、查询、更新。 经过这次数据库系统基础课程设计, 我们不仅及时巩固的了数据库以及软 件工程的知识,并对数据库以及软件工程提供的开发流程和工具对于实现 特定功能程序的重要意义
教师签名 年
4)统计每个学生有成绩的课程门数、平均成绩。
月 日
洛阳师范学院信息技术学院
实验步骤: (算法描述、源程序、操作步骤和方法) 1. 建立男学生的视图(Male_Student)
实验步骤: (算法描述、源程序、操作步骤和方法) where studentno='95001'
update Male_Student set score='95' where studentno='95001' and coursename='数据库'
签名 某某某 2011 年 12 月 27 日 评语与成绩:

实验5 视图的创建与使用

实验5 视图的创建与使用

实验5 视图的创建和使用【实验目的】掌握创建与删除视图的方法掌握更新视图的方法掌握视图的查询操作【实验内容】一、创建视图1、用企业管理器创建视图此实验中以mydb1数据库中的test01、student、course、sc表为基础创建视图。

打开企业管理器,展开左侧窗口树形结构上的数据库节点,选中要创建视图的数据库(这里是mydb1),右击数据库中的“视图”对象,选择“新建视图”命令,如图1所示,就会弹出如图2所示的视图设计器窗口。

图【1】新建视图图【2】视图设计器在视图设计器窗口中右击选择“添加表”或单击工具栏上“添加表”按钮,添加所需要的表。

如图3所示。

图【3】添加表在表窗口中各字段名的前面方框里单击,选择相应的字段,或是在下面“列”的下拉列表框中选择字段,并可在“准则”列中输入提取记录时的过滤条件,在“或”列中输入提取记录所用的附加条件,最后在上面窗口中右击,选择“运行”,则在最下面的窗口中就能看到视图的结果。

如图4所示。

图【4】选择视图内容视图设计完后,点击保存图标,在弹出的“另存为”对话框中输入视图名,此实验为score_view ,最后点击“确定”按钮。

如图5所示。

图【5】保存视图2、使用向导创建视图(略)3、用T-SQL语句创建视图格式:CREATE VIEW view_name[(column1,column2,……)] Asselect_statement[with check option]例:创建所有选课学生的信息视图,如图6所示。

(3)重命名表test001为test01。

当发现表名不恰当的时候,需要为表重新命名。

使用系统存储过程sp_rename 可以为表重新命名,语法如下:sp_rename old_table_name , new_table_name请在查询管理器中输入如下的语句:Use mydb1Gosp_rename test001 , test01 /*EXEC sp_rename test001 , test01 也可以*/Go系统执行,将返回如图6所示的结果。

视图创建和使用

视图创建和使用

实训四视图[实验目的]:•掌握视图的定义与删除;•灵活查询与更新视图。

[实验要求]:利用实验一中创建的六个基本表 s,t,c,sc,tc,d,用SQL语句完成如下操作。

[实验步骤]:一、定义与删除视图•创建一个计算机系教师情况的视图 SUB_T,视图由子查询中的三列TNO,TNAME,PROF组成;create view sub_t as select tno,tname,proffrom twhere dept=' 计算机 '•创建一个学生情况视图,包括学号、姓名、课程名及成绩;create view s_c_sc(sno,sname,cname,score)as select s.sno,sname,cname,scorefrom s,c,scwhere s.sno=sc.sno and o=o•创建一学生平均成绩视图;create view s_avg(sno,avg) as select sno,avg(score)from scgroup by sno•创建数学系学生的视图 MA_S;create view ma_s as select *from swhere dept=' 数学 '•创建数学系选修了 C1号课程的学生的视图;create view ma_c1 as select *from s,scwhere dept=' 数学 'and s.sno=sc.sno and cno='C 1'•将每门课程和它的平均成绩定义为一个视图 CNO_AVG;create view cno_avg(cno,avg_sco) as select cno,avg(score) from scgroup by cno•删除计算机系教师情况的视图。

Drop view sub_t二、查询与更新视图•查找视图 SUB_T中职称为教授的教师号和姓名;select tno,tnamefrom sub_twhere prof=' 教授 '•在视图 MA_S上查询年龄大于20岁的学生信息;select *from ma_swhere age>20•在视图 CNO_AVG中,查询平均成绩大于80分的课程号和平均成绩;select cno,avg_scofrom cno_avgwhere avg_sco>80•向计算机系教师视图 SUB_T中插入一条记录(教师号:T6,姓名:李力,职称:副教授);insert into sub_t(tno,tname,prof)values(‘T 6' ,' 李力 ',' 副教授 ')•将计算机系教师视图 SUB_T中刘伟的职称改为“副教授”;update sub_tset prof=' 副教授 'where tname=' 刘伟 '•删除计算机系教师视图 SUB_T中刘伟教师的记录;deletefrom sub_twhere tname=' 刘伟 '•在视图 MA_S上将学号为“20040102”的学生删除。

创建与使用视图

创建与使用视图

河南城建学院计算机学院《数据库原理》实验报告实验名称:创建与使用视图成绩:专业班级:姓名:学号实验日期:2014年 5 月 22 日软件环境:Windows XP 开发工具:SQL SERVER 2005硬件环境:CPU 硬盘:160G 内存:2G一、实验目的与要求1、掌握创建视图的语法格式2、掌握简单视图和复杂视图3、通过视图查询和修改数据注意:测试教材实例二、实验过程内容及实验数据:1. 创建信息系学生视图create view IS_Studentasselect Sno,Sname,Sagefrom Studentwhere Sdept='IS'2.建立信息系学生视图,并要求进行修改和插入create view IS_Studentasselect Sno,Sname,Sagefrom Studentwhere Sdept='IS'with check option;3.建立信息系选修了1号课程的学生视图create view IS_S1(Sno,Sname,Grade)asselect Student.Sno,Sname,Gradefrom Student,SCwhere Sdept='IS'and Student.Sno=SC.Sno and o='1';4.建立信息系选修1号课程且成绩在90分以上的学生的视图create view IS_S2asselect Sno,Sname,Gradefrom IS_S1where Grade>=90;5.定义一个反映学生出生年份的视图create view BT_S(Sno,Sname,Sbirth)asselect Sno,Sname,2004-Sagefrom Student;6.将学生的学号及他的平均成绩定义一个视图create view S_G(Sno,Gavg)asselect Sno,AVG(Grade)from SCgroup by Sno;7.将Student表中所有女生记录定义一个视图create view F_Student(F_sno,name,sex,age,dept)asselect*from Studentwhere Ssex='女';8.删除视图drop view IS_S1;9.在信息系学生的视图中找出年龄小于20的学生select Sno,Sagefrom IS_Studentwhere Sage<20;10.查询选修了1号课程的信息系的学生select IS_Student.Sno,Snamefrom IS_Student,SCwhere IS_Student.Sno=SC.Sno and o='1';11.在S_G视图中查询平均成绩在85分以上的学生学号和平均成绩select*from S_Gwhere Gavg>=85;12. 在S_G视图中查询平均成绩学生学号和平均成绩select Sno,AVG(Grade)平均分数from SCgroup by Sno;13. 在SC视图中查询平均成绩在86分以上的学生学号和平均成绩select Sno,AVG(Grade)平均分数from SCgroup by Snohaving AVG(Grade)>=86;14.查询信息系学生视图IS_Studentselect*from IS_Student15.将信息系学生视图IS_Student中学号为200215125的学生姓名改为“刘辰”update IS_Studentset Sname='刘辰'where Sno='200215125';16.向信息系学生视图IS_Student中插入一个新的学生记录,其中学号为200215129,姓名为赵新,年龄20岁insertinto IS_Studentvalues ('200215129','赵新',20,'IS');(1)查询select*from IS_Student17.删除信息系学生视图IS_Student中学号为200215129的记录deletefrom IS_Studentwhere Sno='200215129';三、出现问题及解决方案●create view IS_S1(Sno,Sname,Grade)在创建视图的时候出现这种情况,但是不知道怎么解决。

数据库视图创建学习

数据库视图创建学习

数据库视图创建学习实验5 视图的创建及应⽤1、实验⽬的(1)掌握使⽤T-SQL语⾔创建、修改视图;(2)掌握使⽤T-SQL语句删除、重命名视图;(3)掌握使⽤T-SQL语句,通过视图对基本表进⾏数据操作;(4)掌握使⽤界⾯操作的⽅式创建、修改、删除和重命名视图,以及通过视图对基本表进⾏数据操作的⽅法。

2、实验类型验证型、设计型。

3、相关知识视图是⼀种数据库对象,是关系数据库系统提供给⽤户以多种⾓度观察数据库中数据的重要机制。

视图是从⼀个或者多个数据表或视图中导出的虚表,视图的结构和数据是对数据表进⾏查询的结果。

(1)使⽤T-SQL语句创建视图的语法格式CREATE VIEW [ < owner > .] view_name [ ( column_name [ ,...n ] ) ][WITH ENCRYPTION]ASselect_statementFROM table_name WHERE search_condition[WITH CHECK OPTION]其中:n view_name:为新创建的视图指定的名字,视图名称必须符合标识符规则。

n column_name:在视图中包含的列名,也可以在SELECT 语句中指定列名。

n table_name:视图基表的名字。

n select_statement:选择哪些列进⼊视图的SELECT语句。

n WHERE search_condition:基表数据进⼊视图所应满⾜的条件n WITH CHECK OPTION:迫使通过视图执⾏的所有数据修改语句必须符合视图定义中设置的条件。

n WITH ENCRYPTION:对视图的定义进⾏加密。

创建视图时的注意事项:在CREATE VIEW语句中,不能包括ORDER BY、COMPUTE或者COMPUTE BY ⼦句,也不能出现INTO关键字。

创建视图所参考基表的列数最多为1024列。

创建视图不能参考临时表。

实验五:数据库的视图和图表的定义及使用

实验五:数据库的视图和图表的定义及使用
5、编辑数据库图表
在企业管理器中,展开数据库图表所属的服务器、数据库文件夹、数据库以及关系表文件夹。用鼠标右键单击要编辑的关系表,在弹出的菜单中选择“设计关系表”项,则弹出一个编辑关系表的对话框,数据库关系表中的所有操作都是在该对话框中完成的。
6、数据库图表的删除
在企业管理器中,用鼠标右键单击欲删除的数据库关系表。在弹出的菜单上选择“删除”项。在随后出现的删除对象对话框中选中关系表后,单击“删除全部”按钮,即可删除该数据库中被选中的关系表。
ifexists(select*fromsysobjectswherename='Reader')
droptableReader
go
createtableReader(
ReaderIdvarchar(50)primarykey,
Namevarchar(50),
Unitvarchar(50),
Sgenderchar(10)check(Sgender='男'orSgender='女'),
union
select'1003','200215122','2011.02.03'
union
select'1003','200215125','2011.02.03'
union
select'1006','200215126','2011.02.03'
创建视图并修改:
createviewghbas
SELECTdbo.Books.Type,Books.Press,Books.Author,Books.BookName,Books.Price,dbo.Borrow.*
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

实验五视图的创建和使用
【实验目的】
1.利用企业管理器建立视图;
2.利用视图进行查询和修改记录;
【实验内容】
①利用查询分析器和样本(实验一)中的三个表:STUDENTS、SC及C表
建立视图V_grobal,视图V_grobal包含的字段为:
s.sno、、o、ame 、grade
create view V_grobal(sno,sname,cno,cname,grade) as
select student.sno,sname,o,cname,grade
from student,sc,course
where student.sno=sc.sno and o=o
要求从新定义列名
create view
②创建一个名为V_student的视图。

该视图仅查看student表中”1308032”班
的学生信息。

并强制通过视图修改和添加的数据满足where条件。

(with check option)create view
create view V_student
as
select*
from student
where sno like'1308032%'
with check option
1)通过视图修改该班的某一学生的姓名。

能否成功?update V_student
set sname='王里'
where sname='王丽'
可以成功,只有修改学号不能成功。

Update, 能否成功,为什么
2)通过视图修改该班的某一学生的学号改为”130803155”,成功与否?
得到什么结论?
update V_student
set sno='130803155'
试图进行的插入或更新已失败,原因是目标视图或者目标视图所跨越的某一视图指定了WITH CHECK OPTION,而该操作的一个或多个结果行又不符合CHECK OPTION 约束。

语句已终止。

Update, 能否成功,为什么
③创建一个名为V_Sgrade的视图,该视图能显示各学生的学号,姓名,平
均成绩create view
create view V_Sgrade(sno,sname,ave)
as
select sc.sno,sname,avg(grade)
from student,sc
where student.sno=sc.sno
group by sc.sno,sname
问:能不能将某一个学生的平均成绩改成90,为什么?
Update, 能否成功,为什么
update V_Sgrade
set ave=90
where sno=130803101
消息4406,级别16,状态1,第1 行
对视图或函数'V_Sgrade' 的更新或插入失败,因其包含派生域或常量域。

④建立1308031班学生的视图,在1308031班学生的视图中找出年龄小于
20岁的学生。

create view
create view banji
as
select*
from student
where sno like '1308031%'
select * from banji where age<20
⑤建立一反映各学生总成绩的视图S_ZCJ,视图包括学号、姓名、总成绩
三列。

create view
create view S_ZCZ(sno,sname,sumgrade)
as
select student.sno,sname,sum(grade)
from student,sc
where student.sno=sc.sno
group by student.sno,sname
【实验体会及存在问题】(要求自己填写)。

相关文档
最新文档