这种题有两种出题模式:

第一种是给出你含有数字、字母或者属性的几组表格,让你用关系代数运算

第二种是会给出“关系数据库模式”,让我们用“关系代数表达式”表示各种查询,相对第一种较难

今年随机出

让我们来浅看一下概念:

一、关系数据库模式:简记为R(A1,A2,~~~An),R为关系名,A为属性名

eg:公司(公司编号、公司名、地址)

eg:S (S#,SNAME,AGE,SEX)(有的关系模式会是纯英文)

二.关系代数表达式:

交n、并U、差-(高中学过,略)、笛卡尔积x、选择σ、投影Π、连接

 笛卡尔积:

S:

T:

A

B

A

B

3

4

1

5

7

2

3

6

则SxT=

S.AS.BT.AT.B
3415
3436
7215
7236
笛卡尔积是水平方向的运算,第一个表的每行分别与第二个表的每行相连

选择σ:

语法:σ+条件(所查询的表)

eg:商品(商品ID,商品名称,价格,品牌,型号,颜色,生产商,产地)

        查询产地是上海的商品信息:σ产地=‘上海’ (商品)

       选择是水平方向的查询,其结果是符合条件的商品的所有属性(字符串记得加单引号)

投影Π:

eg:商品(商品ID,商品名称,价格,品牌,型号,颜色,生产商,产地)

        查询产地是上海的商品ID,商品名称:Π商品ID,商品名称(σ产地=‘上海’(商品))

        投影是竖直方向的查询,其结果是单个属性

连接:

连接一般用于表格,连接有自然连接、外连接、左连接、右连接。老师不会为难咱们,题库中也只有自然连接题,所以只讲最简单的自然连接

 

 如上所示,连接就是把两个关系中具有相同的属性的行进行笛卡尔运算

除:

上题中R作为被除数,S作为除数

方法:(1)先找出R、S中的共有属性B、C

           (2)再找出被除数R中共有属性值与S中共有属性值相同的行,

                   即R(2):

ABC
a1b1c2
a1b2c3
a2b2c3
a1b2c1
            (3)去掉第二步表R(2)中的共有属性列B、C,只留A列

                        即

A
a1            
 a1
a2
a1
                        化简得

掌握这些基本概念,我们就可以做题啦,SQL的查询方式多样,所以很多题答案不唯一。

例1:真题

解:1.

例2、

解: 

例3、

 

解:

技术
今日推荐
下载桌面版
GitHub
百度网盘(提取码:draw)
Gitee
云服务器优惠
阿里云优惠券
腾讯云优惠券
华为云优惠券
站点信息
问题反馈
邮箱:[email protected]
QQ群:766591547
关注微信