`
chinagdvea
  • 浏览: 132454 次
  • 性别: Icon_minigender_1
  • 来自: 韶关
社区版块
存档分类
最新评论

SQL三范式以及数据模式

SQL 
阅读更多

三范式

  第一范式,1NF:(1).数据列只包含有原子性的值
    (2).没有重复的数据组

   第二范式,2NF:(1)符合第一范式
(2)没有部分函数依赖  (如果location和weather是组合主键,temperature都不是主键,weather改变会引起temperature改变,location改变不会引起temperature改变,
则称temperature对主键有部分依赖)

   第三范式,3NF:(1)符合第二范式
(2)没有传递函数依赖性 (如果weather和temperature都不是主键,但是但weather改变会引起temperature改变时,称两者具有传递函数依赖性)


数据模式

1.一对多关系:如表 person (person_id Primary Key, name, nationality, interest)
      则称nationality和person_id具有一对多关系,因为每一个nationality可能对应多个person_id,但每个person_id只有一个nationality
      此时,将nationality抽取出来,创建表nationality_table ( nationality_id Primary Key, nationality)
      将person表改为 person (person_id PK, name, nationality_id Foreign Key, interest)


2.多对对关系:如表 person (person_id Primary Key, name, nationality, interest)
      则称interest和person_id具有多对多关系,因为每个interest对应多个person_id,而每个person_id对应多个interest
      此时将interest抽取出来,创建新标 interest_table (interest_id PK, interest)
      原person表改为person (person_id Primary Key, name, nationality, interest_id)
      并创建 junction table(连接表)  person_interest (person_id FK, interest_id, FK),用于连接person和interest_table两表
分享到:
评论

相关推荐

    SqlServer 第三范式

    关系数据库的设计理论包括三个方面内容:数据依赖、范式、模式设计方法。核心内容是数据依赖。 关系数据库设计的主要问题是关系模式的设计,关系模式的设计需要解决的问题有:数据冗余、更新异常、插入异常和删除...

    SQL反模式.pdf

    通过对《SQL反模式》这本书的学习,我们可以深刻认识到在数据库设计和SQL编程过程中需要注意的问题,以及如何避免这些常见的陷阱。本书不仅对初学者来说是非常宝贵的资源,对于经验丰富的数据库开发者来说也具有重要...

    Spark SQL上海摩拜共享单车数据分析源码

    通过阅读和理解代码,可以学习到如何在实际项目中应用Spark SQL进行数据处理和分析,以及如何利用Maven管理Java项目。同时,也可以了解到如何处理特定领域的数据,如共享单车行业的数据,从而提升自己的数据分析能力...

    数据库sql期末总复习

    在复习数据库SQL时,我们需要涵盖多个关键知识点,这些知识点包括数据库系统的基本概念、数据模型、数据库系统的结构、关系数据库、SQL语句、安全性以及完整性等。 1. **数据库系统概述**: - 数据、DB(数据库)...

    数据库系统概念大学模式sql文件

    1. 数据库设计:理解如何根据业务需求定义实体和关系,创建符合第三范式(3NF)或BCNF的表结构。 2. SQL基础:学习SELECT、INSERT、UPDATE、DELETE等基本SQL语句,以及JOIN、GROUP BY、HAVING等高级查询技巧。 3. ...

    SQL期中考试题目

    SQL期中考试主要涵盖数据库系统的基础知识,包括数据独立性、关系模式、规范化、函数依赖、数据查询和完整性约束等方面。以下是对这些知识点的详细解释: 1. **数据独立性**:数据独立性是数据库设计的重要原则,它...

    SQL反模式PDF

    3. **范式理论**: 书中会详细介绍第一范式(1NF)、第二范式(2NF)、第三范式(3NF)以及更高阶的BCNF(巴斯-科德范式)等,这些都是理解数据库规范化的重要基础。 4. **数据冗余的危害**: 数据冗余可能导致数据不...

    SQL反模式设计

    在数据库设计领域,"SQL反模式"是一个重要的概念,它指的是在实践中常见但可能导致性能下降、数据不一致或维护困难的设计方法。理解SQL反模式有助于我们避免这些常见错误,提高数据库系统的效率和可维护性。这里我们...

    SQL权威指南 第4版

    2. **数据库设计**:深入讨论了关系模型理论,包括范式理论,以及如何设计符合第三范式和BCNF(Boyce-Codd Normal Form)的数据库模式。 3. **联接与子查询**:详述了不同类型的联接(内连接、外连接、交叉连接)和...

    SQL Server数据应用开发

    这包括了概念设计、逻辑设计和物理设计,需要理解范式理论,如第一范式(1NF)、第二范式(2NF)和第三范式(3NF),以及如何避免数据冗余和异常。 4. **索引与查询优化**:理解索引的工作原理,如何创建B树索引、...

    SQL 教案.rar

    这包括了范式理论,如第一范式(1NF)、第二范式(2NF)和第三范式(3NF),以及反范式化设计在特定场景下的应用。 3. **T-SQL扩展**:SQL Server 2000支持Transact-SQL(T-SQL),这是SQL的一个扩展,增加了如存储...

    SQL语言参考大全chm版

    8. **数据库设计**: 正确设计数据库模式,理解范式理论(1NF、2NF、3NF等),以及如何通过外键实现数据之间的关系。 9. **SQL优化**: 学习如何编写高效的SQL查询,包括避免全表扫描、使用索引、合理设计数据模型...

    sql数据库设计教程

    3. 正范式(Normal Forms):教程会讲解第一范式(1NF)、第二范式(2NF)、第三范式(3NF)和BCNF(巴斯-科德范式),以及它们在减少数据冗余和确保数据一致性中的作用。 4. 关系数据库设计:这包括如何创建数据库...

    SQL反模式(中文完整版)

    《SQL反模式》是数据库设计和SQL编程领域中一本极具影响力的书籍,它深入探讨了在实践中容易出现的问题以及如何避免这些“反模式”。SQL反模式指的是在使用SQL进行数据库设计和查询时,可能导致性能低下、可维护性差...

    SQL反模式-逻辑数据库设计反模式

    正确的做法是采用第三范式(3NF)或更高级的范式来设计数据库,减少冗余,保证数据的一致性。 其次,“过度规范化”也是一个常见的反模式。虽然规范化有助于减少数据冗余,但如果过度规范化,可能会增加查询复杂性...

    .net sqlserver 学习数据文件

    9. **数据库设计原则**:学习如何设计高效且易于维护的数据库模式,包括范式理论、索引策略和数据规范化。 10. **性能优化**:理解查询优化器的工作原理,学习索引的创建和管理,以及如何通过调整查询语句或数据库...

    数据库系统原理与应用(第三版)(SQL Server 2012)-电子教案.rar

    在本教程中,你会学习到需求分析、概念设计、逻辑设计和物理设计的全过程,以及规范化理论,如第一范式(1NF)、第二范式(2NF)和第三范式(3NF),以优化数据存储并减少冗余。 事务处理是确保数据一致性、完整性...

Global site tag (gtag.js) - Google Analytics