第二章 关系数据库

第二章 关系数据库

2.1 关系数据库及形式化定义

  • 关系数据库系统是支持关系模型的数据库系统
  • 3 要素
    • 关系数据结构
    • 关系操作集合
    • 关系完整性约束

2.1.1 关系数据结构

  • 数据结构---关系----二维表
  • 域(Domain) 一组具有相同数据类型的值得集合
  • 笛卡尔积(Cartesian Product)
  • 关系(Relation): 就是实体的属性
    候选码(Candiate key) 主码(Primary key) 非主属性(Nonprimary attribute) 非码属性(Non-key attribute) 全码(All-key)
  • 关系的三种类型: 基本关系(基本表,基表),查询表, 视图表
    • 基本表: 实际存在的表, 它是实际存储数据的逻辑表示
    • 查询表: 是查询结果对应的表
    • 视图表: 由基本表或其他视图表导出的表, 是虚表, 不对应实际存储的数据

    在实际的sql server 数据库中工程中, 也会显示这三种表


关系模式

  • 关系模式是型, 关系是值
  • 关系的描述称为关系模式(Relation Schema) 表示为 R(U,D,DOM, F)
    R: 关系名 U: 关系的属性名集合 D: 属性组U中属性所带来的域 DOM: 属性向域的映像集合 F: 属性间数据的依赖关系集合

2.1.3 关系数据库

- 关系数据库的值是这些关系模式在某一时刻对应的关系的集合
    - 若干域的定义
    - 在这些域上定义的若干关系模式

2.2 关系操作

2.2.1 基本关系操作

  • 关系操作
    • 查询(Query)
      • 选择(Select) 投影(Project) 链接(Join) 除(Divide) 并(Union) 差(Except) 交(Intersection) 笛卡尔积
    • 插入(Insert) 删除(Delete) 修改(Update)

2.2.2 关系数据语言分类

  • 关系代数: 对关系的运算来表达查询要求

  • 关系演算: 用谓词来表达查询要求

  • 关系演算: 可按谓词变元的基本对象是元组变量还是域变量分为元组关系演算和域关系演算,

  • 关系数据语言分类:

    • 关系代数语言 例如 ISBL
    • 关系演算语言
      • 元组关系演算语言 例如 APLHA, QUEL
      • 域关系演算语言 例如 QBE
    • 基友关系代数和关系演算双重特点的语言 例如 SQL

关系完整性

关系的三类完整性约束

  • 实体完整性 (必要)
  • 参照完整性 (必要)
  • 用户定义的完整性

2.3.2 实体完整性(Entity Integrity)

  • 规则: 实体完整性规则 若属性(指一个或一组属性)A 是基本关系 R 的主属性, 则 A 不能取空值

2.3.3 参照完整性

  • 定义: 设 F 是基本关系 R 的一个或一组属性, 但不是关系 R 的码. Kt 是基本关系 S 的主码, 如果 F 与 Kt 相对应, 则称 F 是 R 的外码(Foreign Key) 并称基本关系 R 为参照关系(Referencing Relation) , 基本关系 S 为被参照关系(Referenced Relation) 或目标关系(Target Relation), 关系 R 和 S 不一定是不同的关系
  • 规则 参照完整性规则: 若属性(或属性组) F 是基本关系 R 的外码, 它与基本关系 S 的主码 Kt 相对应(基本关系 R 和 S 不一定是不同的关系), 则对于 R 中每个元祖在 F 上的值必须为:
    • 或者取空值( F 的每个属性值均为空值)
    • 或者等于 S 中某个元组的主码值

2.3.4 用户定义的完整性(User-defined Integrity)

  • 用户定义的完整性是针对 某一具体关系数据库的约束条件. 它反映某一具体应用所涉及的数据必须满足的语义要求

2.4 关系代数

  • 关系代数是一种抽象的查询语言, 它用对关系的运算来表达查询

2.4.1 传统的集合运算

  • 并(Unicon)
  • 差(Except)
  • 交(Intersection)
  • 笛卡尔积(Cartesian Product)

2.4.2 专门的关系运算

  • 选择(Selection)
  • 投影(Projection): 取表中的某几列重新组成一个表
  • 链接(Join): 对笛卡尔积的结果进行筛选
    • 等值链接: 找到两个表中相同的列, 这两个列中值相同的行的集合
    • 自然链接: 对等值链接的变形, 把等值链接中那两个相同的列合并成一列
  • 除运算(Division) : R(X,Y) ÷ S(Y,Z) , 结果是一个元组. 这个元组在 X 上分量值 x 的 象集为 Yx, S 在 Y 上的投影集合为 Ys, Ys 是 Yx 的子集.

关系演算

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,968评论 6 482
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,601评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 153,220评论 0 344
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,416评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,425评论 5 374
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,144评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,432评论 3 401
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,088评论 0 261
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,586评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,028评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,137评论 1 334
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,783评论 4 324
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,343评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,333评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,559评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,595评论 2 355
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,901评论 2 345

推荐阅读更多精彩内容