第三章 课后题答案.doc_第1页
第三章 课后题答案.doc_第2页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

第3章 sql语言1. 试述sql语言的特点。答:综合统一、高度非过程化、面向集合的操作方式、以同一种语法结构提供两种使用方式、语言简捷,易学易用。2. 试述sql的定义功能。答:sql的数据定义功能包括定义表、定义视图和定义索引用sql语句建立第二章习题5中的四个表。s(sno,sname,status,city); p(pno,pname,color,weight); j(jno,jname,city); spj(sno,pno,jno,qty); 供应商表s由供应商代码(sno)、供应商姓名(sname)、供应商状态(status)、供应商所在城市(city)组成:create table s(sno c(2) unique,sname c(6) ,status n(2),city c(4)零件表p由零件代码(pno)、零件名(pname)、颜色(color)、重量(weight)组成:create table p(pno c(2) unique,pname c(6),color c(2), weight i(2)工程项目表j由工程项目代码(jno)、工程项目名(jname)、所在城市(city)组成:create table j(jno c(2) unlque,jname c(8), city c(4)供应情况表spj由供应商代码(sno)、零件代码(pno)、工程项目代码(jno)、供应数量(qty)组成:create table spj(sno c(2),pno c(2),jno c(2), qty n(2)4针对上题中建立的四个表试用sql语言完成第二章习题5中的查询:求供应工程j1零件的供应商号码sno:select dist sno from spj where jno=j1求供应工程j1零件p1的供应商号码sno:select dist sno from spj where jno=j1 and pno=p1求供应工程j1零件为红色的供应商号码sno:select sno from spj,p where jno=j1 and spj.pno=p.pno and color=红求没有使用天津供应商生产的红色零件的工程号jno:select dist jno from spj where jno not in (sele jno from spj,p,s where s.city=天津 and color=红 and s.sno=spj.sno and p.pno=spj.pno)。 求至少用了供应商s1所供应的全部零件的工程号jno。 由于vfp不允许子查询嵌套太深,将查询分为两步a、查询s1供应商供应的零件号select dist pno from spj where sno=s1结果是(p1,p2)b、查询哪一个工程既使用p1零件又使用p2零件。select jno from spj where pno=p1 and jno in (select jno from spj where pno=p2)5针对习题3中的四个表试用sql语言完成以下各项操作: (1)找出所有供应商的姓名和所在城市。 select sname,city from s(2)找出所有零件的名称、颜色、重量。select pname,color,weight from p (3)找出使用供应商s1所供应零件的工程号码。 select dist jno from spj where sno=s1(4)找出工程项目j2使用的各种零件的名称及其数量。select pname,qty from spj,p where p.pno=spj.pno and spj.jno=j2 (5)找出上海厂商供应的所有零件号码。select pno from spj,s where s.sno=spj.sno and city=上海(6)出使用上海产的零件的工程名称。select jname from spj,s,jwhere s.sno=spj.sno and s.city=上海 and j.jno=spj.jno (7)找出没有使用天津产的零件的工程号码。注意: select disp jno from spj where jno not in (select dist jno from spj,s where s.sno=spj.sno and s.city=天津) 适用于jno是唯一或不唯一的情况. 注意: select dist jno from spj,s where s.sno=spj.sno and s.city天津适用于jno是唯一的情况(8)把全部红色零件的颜色改成蓝色。update p set color=蓝 where color=红(9)由s5供给j4的零件p6改为由s3供应。 update spj set sno=s3 where sno=s5 and jno=j4 and pno=p6(10)从供应商关系中删除供应商号是s2的记录,并从供应情况关系中删除相应的记录。 a、delete from s where sno=s2 b、delete from spj where sno=s2(11)请将(s2,j6,p4,200)插入供应情况关系。 insert into spj values(s2,j6,p4,200)6什么是基本表?什么是视图?两者的区别和联系是什么?基本表是本身独立存在的表,在sql中一个关系就对应一个表。一个(或多个)基本表对应一个存储文件,一个表可以带若干索引,索引也存放在存储文件中。 视图是从一个或几个基本表导出的表。它本身不独立存储在数据库中,即数据库中只存放视图的定义而不存放视图对应的数据,这些数据仍存放在导出视图的基本表中,因此视图是一个虚表。视图在概念上与基本表等同,用户可以在视图上再定义视图。7试述视图的优点。答:视图能够简化用户的操作、视图使用户能以多种角度看待同一数据、视图对重构数据库提供了一定程度的逻辑独立性、视图能够对机密数据提供安全保护。8所有的视图是否都可以更新?为什么?答:并不是所有的视图都是可更新的,因为有些视图的更新不能唯一地有意义地转换成对相应基本表的更新。9哪类视图是可以更新的,哪类视图是不可更新的? 各举一例说明。行列子集视图是可更新的。除行列子集视图外,还有些视图理论上是可更新的,但它们的确切特征还是尚待研究的课题。还有些视图从理论上不可更新的。10试述某个你热悉的实际系统中对视图更新的规定。11请为三建工程项目建立一个供应情况的视图,包括供应商代码(sno)、零件代码(pno)、供应数量(qty)。create view vsp as select sno,pno,qty from spj,j where

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论