`

有关数据库的外键约束

阅读更多

1.主键(PRIMARY   KEY)约束  
      一个表通常可以通过一列和多列组合的数据来唯一标识表中的每一列,这些列和列组合  
  就被称为表上的主键,它可以用来强制实体完整性。  
      当一个表指定了PRIMARY   KEY约束时,SQL   SERVER通过为主键列上建立唯一索引来强制  
  数据的唯一性。唯一性索引在主键被用于查询时可以对数据进行快速访问。  


  2.外键(FOREIGN   KEY)约束  
      外键也是由一列或多列构成的,它用来建立和强制两个表间的关联。这种关联是通过将  
  一个表中的组成主键的列或组合列加入到另一个表中形成的,这个列或组合列就成了第二  
  个表中的外键。  
      一个FOREIGN   KEY约束并不一定要求必须与另一个表上的PRIMARY   KEY约束相关联,它还  
  可以被定义为对另一个列中的UNIQUE约束的一个引用。FOREIGN   KEY约束可以允许空值,但  
  是形成外键的列或组合列中出现空值时将跳过对FOREIGN   KEY约束的验证。当向表中添加新  
  数据行或修改已有的数据行时,在外键中的定义的列或组合列必须在其他表的主键中存在或  
  是为空,否则将会出错。  
  注意:FOREIGN   KEY约束可以对同一个数据库中的其他表上的列或组合列进行引用,也可以  
  是对自身表中其他列或组合列的引用(自引用表)  
      尽管外键的主要作用是用来限制可以输入到外键表中的数据,但是还可以限制对主键表中  
  数据的修改。  
      FOREIGN   KEY约束也可以被用作索引,这是因为:  
      1.对FOREIGN   KEY约束的修改或被在其他表中的FOREIGN   KEY约束所检查  
      2.外键列或组合列也常常被用于查询中,对于在具有FOREIGN   KEY约束的表和其他有主键或  
  唯一键的表间进行查询时,可以在连接准则中使用外键列或组合列。索引允许SQL   SERVER在  
  外键中进行快速查找。但是对这样的索引的创建并不是必需的。   
 

 

外键   (FK)   是用于建立和加强两个表数据之间的链接的一列或多列。通过将保存表中主键值的一列或多列添加到另一个表中,可创建两个表之间的链接。这个列就成为第二个表的外键。  
   
  当创建或更改表时可通过定义   FOREIGN   KEY   约束来创建外键。  
   
  例如,数据库   pubs   中的   titles   表与   publishers   表有链接,因为在书名和出版商之间存在逻辑联系。titles   表中的   pub_id   列与   publishers   表中的主键列相对应。titles   表中的   pub_id   列是到   publishers   表的外键。   
        
  FOREIGN   KEY   约束并不仅仅只可以与另一表的   PRIMARY   KEY   约束相链接,它还可以定义为引用另一表的   UNIQUE   约束。FOREIGN   KEY   约束不允许空值,但是,如果任何组合   FOREIGN   KEY   约束的列包含空值,则将跳过   FOREIGN   KEY   约束的校验。       
    
  说明     FOREIGN   KEY   约束可引用同一数据库中的表或同一表(自引用表)内的列,例如,一个包含下面三列的雇员表:employee_number、employee_name   和   manager_   employee_number。由于经理本身也是雇员,所以从   manager_employee_number   列到   employee_number   列存在外键关系。   
        
  尽管   FOREIGN   KEY   约束的主要目的是控制存储在外键表中的数据,但它还可以控制对主键表中数据的修改。例如,如果在   publishers   表中删除一个出版商,而这个出版商的   ID   在   titles   表中记录书的信息时使用了,则这两个表之间关联的完整性将被破坏,titles   表中该出版商的书籍因为与   publishers   表中的数据没有链接而变得孤立了。FOREIGN   KEY   约束防止这种情况的发生。如果主键表中数据的更改使之与外键表中数据的链接失效,则这种更改是不能实现的,从而确保了引用完整性。如果试图删除主键表中的行或更改主键值,而该主键值与另一个表的   FOREIGN   KEY   约束值相关,则该操作不可实现。若要成功更改或删除   FOREIGN   KEY   约束的行,可以先在外键表中删除外键数据或更改外键数据,然后将外键链接到不同的主键数据上去。   
   

分享到:
评论

相关推荐

    数据库外键约束方式

    数据库外键约束方式 外键约束是数据库中实现参照完整性的重要手段,它能够确保数据的一致性和正确性。外键约束方式有多种,包括级联、置空和禁止三种方式。 级联(Cascade)方式是指当主表中的记录被删除或更新时...

    数据库外键约束的作用与实现

    外键约束是数据库中维护数据完整性和一致性的重要工具。通过合理使用外键约束,可以有效...本文详细介绍了外键约束的作用、实现方法和性能优化策略,并提供了代码示例,希望能帮助读者更好地理解和应用数据库外键约束。

    数据库下所有表的外键约束查询

    用于查询某个数据库下所有表的外键约束情况,以便统一分析外键约束是否合理;主要查询出外键的,是否级联删除,级联更新,强制外键约束,强制复制约束始终状态。如想使用别的状态,请自行添加。下载的童鞋别下载错了...

    数据库表排序,主表子表放置外键约束

    "数据库表排序,主表子表放置外键约束"这一主题涉及到数据库规范化、外键约束、数据导入以及程序化解决方案。下面将详细阐述这些知识点。 首先,**外键约束**是关系数据库中的一种机制,用于确保一个表(子表)中的...

    禁用启用所有外键约束.tst

    在数据库管理中,外键约束是关系数据库设计中的一个重要概念,用于维护数据的一致性和完整性。外键约束确保了引用的完整性,即一个表中的外键值必须是另一个表中存在的主键值。在进行大规模数据导入、更新或者调试时...

    Oracle定义约束 外键约束

    本文将详细介绍如何在Oracle数据库中使用**外键约束**来确保数据的参照完整性。 #### 二、什么是外键约束 外键约束是一种用于保证两个表之间数据一致性的机制。当两个表存在关联时,通过在外键表(子表)中设置外键...

    MySQL删除表的时候忽略外键约束的简单实现

    在MySQL数据库管理中,删除表是一项需要谨慎操作的任务,尤其是当表之间存在外键约束时。外键约束是关系数据库中确保数据完整性和一致性的重要机制,它不允许在父表(引用其他表的字段的表)中删除那些已被子表引用...

    sql外键约束

    3. **事务一致性**:在多表操作的事务中,外键约束有助于保持事务的一致性,确保相关数据的正确同步。 4. **业务规则**:外键约束可以作为业务逻辑的一部分,限制某些操作,如防止非法的用户操作,确保数据遵循特定...

    数据库技术与应用 外键约束-A学习任务书.doc

    在数据库技术中,外键约束是一项至关重要的概念,它确保了数据的一致性和完整性。外键约束是关系数据库设计中的一个关键元素,特别是在实施参照完整性的场景下。本学习任务书将带你深入理解和掌握外键约束的应用。 ...

    自动删除所有表,有外键约束的表优先删除

    标题"自动删除所有表,有外键约束的表优先删除"涉及到的是一个数据库操作的场景,通常需要谨慎处理,因为错误的操作可能导致数据丢失或破坏数据库结构。在这个问题中,我们关注的是如何在有外键约束的环境中安全地...

    用触发器实现SQLite的外键约束

    通过上述方法,我们可以有效地在SQLite数据库中实现外键约束的功能,从而确保数据的一致性和完整性。这种方法虽然比内置的外键支持稍微复杂一些,但在SQLite这样的轻量级数据库系统中非常实用。需要注意的是,由于...

    数据库技术与应用 外键约束-D习题与作业.doc

    在数据库技术中,外键约束是一项至关重要的概念,它确保了数据的一致性和完整性,是关系数据库模型中的关键组成部分。本篇将详细讲解外键约束的含义、作用以及如何在实际应用中设置。 首先,外键(Foreign Key,...

    MLDN魔乐科技_Oracle课堂18_外键约束

    在数据库设计中,外键约束是一项至关重要的概念,它确保了数据的一致性和完整性。本课程"MLDN魔乐科技_Oracle课堂18_外键约束"深入讲解了Oracle数据库中如何利用外键来实现关系间的引用完整性。下面将详细阐述外键...

    数据库技术与应用 设置学生表外键约束-A学习任务书.doc

    在数据库技术中,外键约束是关系数据库设计中不可或缺的一部分,它主要用于确保数据的一致性和完整性。本学习任务书将重点讲解如何在学生表中设置外键约束,以实现不同表之间的关联,这对于电子信息工程技术专业的...

    MySQL的约束-外键约束

    本文将深入探讨其中的一种约束类型——外键约束(Foreign Key Constraint),它是关系数据库模型中的核心概念,用于建立和维护不同表之间的关联。 外键约束允许一个表中的数据引用另一个表中的数据,这种引用关系...

    数据库主外键详解

    数据库外键(Foreign Key)是表中的一个字段,它用于引用另一个表中的主键,用于建立表之间的关系。外键的目的是为了维护数据的一致性和完整性,避免数据中的不一致和错误。 创建外键约束时,需要指定引用哪个表的...

    MySQL外键约束常见操作方法示例【查看、添加、修改、删除】

    在MySQL数据库中,外键约束是关系型数据库中用于维护数据完整性和一致性的重要工具。它确保了一张表中的数据与另一张表的数据之间的关联性,通常用于实现一对一、一对多或多对多的关系。本篇文章将详细讲解如何进行...

    数据一致性守护者:MySQL外键约束深度解析

    通过合理地设计和利用外键约束,可以有效地避免数据不一致的问题,确保数据库的健康和稳定运行。无论是对于初学者还是经验丰富的开发者来说,深入理解并熟练掌握外键约束的应用都是十分必要的。

Global site tag (gtag.js) - Google Analytics