第2章 关系数据库(数据库系统概论)

1 .试述关系模型的三个组成部分。
答:关系模型由关系数据结构、关系操作集合和关系完整性约束三部分组成。

2 .试述关系数据语言的特点和分类。
答:关系数据语言可以分为三类:
关系代数语言。
关系演算语言:元组关系演算语言和域关系演算语言。
SQL:具有关系代数和关系演算双重特点的语言。
这些关系数据语言的共同特点是,语言具有完备的表达能力,是非过程化的集合操作语言,功能强,能够嵌入高级语言中使用。

4 .试述关系模型的完整性规则。在参照完整性中,为什么外部码属性的值也可以为空?什么情况下才可以为空?

答:实体完整性规则是指若属性A是基本关系R的主属性,则属性A不能取空值。
若属性(或属性组)F是基本关系R的外码,它与基本关系S的主码Ks相对应(基本关系R和S不一定是不同的关系),则对于R中每个元组在F上的值必须为:或者取空值(F的每个属性值均为空值);或者等于S中某个元组的主码值。即属性F本身不是主属性,则可以取空值,否则不能取空值

5.设有一个SPJ数据库,包括S,P,J,SPJ四个关系模式:
   S( SNO,SNAME,STATUS,CITY);
   P(PNO,PNAME,COLOR,WEIGHT);
   J(JNO,JNAME,CITY);
   SPJ(SNO,PNO,JNO,QTY);
  供应商表S由供应商代码(SNO)、供应商姓名(SNAME)、供应商状态(STATUS)、供应商所在城市(CITY)组成;零件表P由零件代码(PNO)、零件名(PNAME)、颜色(COLOR)、重量(WEIGHT)组成;工程项目表J由工程项目代码(JNO)、工程项目名(JNAME)、工程项目所在城市(CITY)组成;供应情况表SPJ由供应商代码(SNO)、零件代码(PNO)、工程项目代码(JNO)、供应数量(QTY)组成,表示某供应商供应某种零件给某工程项目的数量为QTY。
  试用关系代数完成如下查询:

 

Sno sname status city
s1 精益 20 天津
s2 盛锡 10 北京
s3 东方红 30 北京
s4 丰泰盛 20 天津
s5 为民 30 上海 

 

P:pno pname color weight
P1 螺母 红 12
P2 螺栓 绿 17
P3 螺丝刀 蓝 14
P4 螺丝刀 红 14
P5 凸轮 蓝 40
P6 齿轮 红 30

J:JNO JNAME CITY
J1 三建 北京
J2 一汽 长春
J3 弹簧厂 天津
J4 造船厂 天津
J5 机车厂 唐山
J6 无线电厂 常州
J7 半导体厂 南京

SPJ:SNO PNO JNO QTY
S1 P1 J1 200
S1 P1 J3 100
S1 P1 J4 700
S1 P2 J2 100
S2 P3 J1 400
S2 P3 J2 200
S2 P3 J4 500
S2 P3 J5 400
S2 P5 J1 400
S2 P5 J2 100
S3 P1 J1 200
S3 P3 J1 200
S4 P5 J1 100
S4 P6 J3 300
S4 P6 J4 200
S5 P2 J4 100
S5 P3 J1 200
S5 P6 J2 200
S5 P6 J4 500 
  (1) 求供应工程J1零件的供应商号码SNO;

        πSno(σJno=‘J1’(SPJ))
        SELECT DIST SNO FROM SPJ WHERE  JNO=’J1’
  (2) 求供应工程J1零件P1的供应商号码SNO;
        πSno(σSno=‘J1’∧Pno=‘P1‘(SPJ))
        SELECT  DIST SNO FROM SPJ WHERE JNO='J1' AND PNO='P1'
  (3) 求供应工程J1零件为红色的供应商号码SNO;
        πSno(σPno=‘P1‘ (σCOLOR=’红‘ (P)∞SPJ))
        SELECT SNO FROM SPJ,P WHERE JNO='J1' AND SPJ.PNO=P.PNO AND COLOR='红'
  (4) 求没有使用天津供应商生产的红色零件的工程号JNO;
        πJno(SPJ)- πJNO(σcity=‘天津’∧Color=‘红‘ (S∞SPJ∞P))
        SELECT  DIST  JNO FROM SPJ  WHERE JNO NOT IN (SELECT JNO FROM SPJ,P,S WHERE S.CITY='天津' AND COLOR='红' AND S.SNO=SPJ.SNO  AND P.PNO=SPJ.PNO)
  (5) 求至少用了供应商S1所供应的全部零件的工程号JNO。
        πJno,Pno(SPJ)÷ πPno(σSno=‘S1‘ (SPJ))
        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')

 

 

6.试述等值连接与自然连接的区别和联系。

答:连接运算符是“=”的连接运算称为等值连接。它是从关系R与S的广义笛卡尔积中选取A,B属性值相等的那些元组
自然连接是一种特殊的等值连接,它要求两个关系中进行比较的分量必须是相同的属性组,并且在结果中把重复的属性列去掉。

7.关系代数的基本运算有哪些 ? 如何用这些基本运算来表示其他运算?
答:并、差、笛卡尔积、投影和选择5种运算为基本的运算。其他3种运算,即交、连接和除,均可以用这5种基本运算来表达。
 

 


 

s(sno,sname,status,address) 零件表 p(pno,pname,color,weight) 工程表 j(jno,jname,city) 供应表 spj(sno,pno,jno,quantity) 其,sno表示供应商编号,sname表示供应商名称,status表示供应商状态,address表示供应商地址;pno表示零件编号,pname表示零件名称,color表示零件颜色,weight表示零件重量;jno表示工程编号,jname表示工程名称,city表示工程所在城市;quantity表示供应商向工程提供的零件数量。 该数据库包括四个关系模式,它们分别为供应商表s,零件表p,工程表j和供应表spj。这四个表通过其关系模式的共同属性来建立关联。 供应商表s记录了各个供应商的信息,包括供应商编号、供应商名称、供应商状态和供应商地址。零件表p记录了各个零件的信息,包括零件编号、零件名称、零件颜色和零件重量。工程表j记录了各个工程的信息,包括工程编号、工程名称和工程所在城市。供应表spj记录了供应商向工程提供的零件信息,包括供应商编号、零件编号、工程编号和供应数量。 这样的数据库可以用于管理供应商、零件和工程的相关信息,使得可以方便地查询某个工程所使用的零件及其供应商的信息,或者查询某个供应商所供应的零件和相关的工程信息。同时,该数据库也可以对供应商、零件和工程进行管理和统计分析,提供数据支持和决策依据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

进击的横打

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值