数据库的约束有哪些

数据库的约束有:1、主键约束;2、非空约束;3、自增长约束;4、非负约束;5、少数约束;6、外键约束。主键约束是指,主键修饰的字段,非空且少数,一张表中只能有一个主键。

数据库的约束有哪些-Worktile社区

1、主键约束

主键约束在表中定义一个主键来少数确定表中每一行数据的标识符。

特点:

  • 主键约束相当于少数性约束+ 非空约束,主键约束不允许重复,也不允许出现空值;
  • 一个表非常多只能有一个主键约束,建立主键约束可以在列级别创建,也可以再表级别创建;
  • 主键约束对应着表中的一列或者多列,对应着多列的时候就是复合主键(可以类比我们之前讲过的复合少数性约束);
  • 如果是多列组合的复合主键约束,那么这些列都不允许为空值,并且组合的值也不允许重复;
  • MySQL中的主键约束名永远都是PRIMARY,就算我们自己命名了主键约束名,这个时候主键约束名也还是PRIMARY,不会改变;
  • 当创建主键约束时,系统默认会在主键约束所在的列或者列组合上建立对应的主键索引,如果删除主键约束,那么主键索引也就自动删除了。当一个表中有主键约束时,系统会默认根据主键约束对应的主键索引来构建一个B+tree的结构,用于存储表中的数据,在这种B+tree的结构下查询的效率更高;
  • 需要注意:不要修改主键字段的值,因为主键是数据记录的少数标识,如果修改了主键的值,就有可能会破坏数据的完整性。

2、非空约束

非空约束指的是表中的某一个字段的内容不允许为空,如果要使用非空约束,只需要在每个列的后面利用“NOT NULL”声明即可。

特点:

  • 默认,所有的类型的值都可以是NULL,包括INT、FLOAT等数据类型
  • 非空约束只能出现在表对象的列上,只能某个列单独限定非空,不能组合非空
  • 一个表可以有很多列都分别限定了非空
  • 空字符串’’不等于NULL,0也不等于NULL

3、自增长约束

在 MySQL 中,当主键定义为自增长后,这个主键的值就不再需要用户输入数据了,而由数据库系统根据定义自动赋值。每增加一条记录,主键会自动以相同的步长进行增长。

特点:

  • 默认情况下,auto_increment的初始值是 1,每新增一条记录,字段值自动加 1。
  • 一个表中只能有一个字段使用 auto_increment约束,且该字段必须有少数索引,以避免序号重复(即为主键或主键的一部分)。
  • auto_increment约束的字段必须具备 NOT NULL 属性。
  • auto_increment约束的字段只能是整数类型(TINYINT、SMALLINT、INT、BIGINT 等。
  • auto_increment约束字段的最大值受该字段的数据类型约束,如果达到上限,auto_increment就会失效。

4、非负约束

指定某列不可存储负值,添加非负约束后,取值范围将发生变化,例如int范围是-128~127,添加非负约束后将变成0-255。

5、少数约束

少数约束(Unique Key)是指所有记录中字段的值不能重复出现。例如,为 id 字段加上少数性约束后,每条记录的 id 值都是少数的,不能出现重复的情况。少数约束保证在一个字段或者一组字段里的数据与表中其它行的数据相比是少数的。

少数约束SQL实现:

CREATE TABLE OnlyConstraint
(ConstraintColumnOne VARCHAR(20) NOT NULL UNIQUE,
ConstraintColumnTwo VARCHAR(20) NOT NULL,
CONSTRAINT UK_OnlyConstraint_ConstraintColumnTwo UNIQUE(ConstraintColumnTwo) )
GO

6、外键约束

FOREIGN KEY是表的一个特殊字段,经常与主键约束一起使用。对于两个具有关联关系的表而言,相关联字段中主键所在的表就是主表(父表),外键所在的表就是从表(子表)。外键用来建立主表与从表的关联关系,为两个表的数据建立连接,约束两个表中数据的一致性和完整性。

定义外键时,需要遵守下列规则:

  • 主表必须已经存在于数据库中,或者是当前正在创建的表。如果是后一种情况,则主表与从表是同一个表,这样的表称为自参照表,这种结构称为自参照完整性。
  • 必须为主表定义主键。
  • 主键不能包含空值,但允许在外键中出现空值。也就是说,只要外键的每个非空值出现在指定的主键中,这个外键的内容就是正确的。
  • 在主表的表名后面指定列名或列名的组合。这个列或列的组合必须是主表的主键或候选键。
  • 外键中列的数目必须和主表的主键中列的数目相同。
  • 外键中列的数据类型必须和主表主键中对应列的数据类型相同。

延伸阅读

数据库的三大范式

  • 名列前茅范式:当关系模式R的所有属性都不能在分解为更基本的数据单位时,称R是满足名列前茅范式的,简记为1NF。满足名列前茅范式是关系模式规范化的最低要求,否则,将有很多基本操作在这样的关系模式中实现不了。
  • 第二范式:如果关系模式R满足名列前茅范式,并且R得所有非主属性都完全依赖于R的每一个候选关键属性,称R满足第二范式,简记为2NF。
  • 第三范式:设R是一个满足名列前茅范式条件的关系模式,X是R的任意属性集,如果X非传递依赖于R的任意一个候选关键字,称R满足第三范式,简记为3NF。

文章标题:数据库的约束有哪些,发布者:Z, ZLW,转载请注明出处:https://worktile.com/kb/p/34588

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
Z, ZLW的头像Z, ZLW
上一篇 2023年1月6日 上午5:59
下一篇 2023年1月6日 上午6:30

相关推荐

  • 项目的什么不包含管理储备

    项目的成本计划、风险应对策略、进度计划以及范围描述是不包含管理储备的。在项目管理中,管理储备是为了应对项目中无法预见的风险而设立的一种预算,它不包含在项目的初步预算中,也不包含在项目的成本基准中。这是因为管理储备的使用需要得到高层管理人员的批准,因此,它并不属于项目经理可以自由支配的资源。在具体实施…

    2024年8月7日
    600
  • 项目管理目标 ci目标是什么

    在项目管理中,CI目标是指持续集成目标,这是一种软件开发实践,它要求团队频繁地将代码集成到一个共享的主线中。CI目标主要包括:减少集成问题、提高软件质量、加速软件发布。 持续集成通过自动化的构建和测试,可以发现并修复集成问题,从而避免了“集成地狱”的情况。这有利于提高团队的效率,减少重复的工作,帮助…

    2024年8月7日
    400
  • 文化项目运行管理是什么

    文化项目运行管理包括:项目规划、资源配置、进度控制、成本管理、风险管理。项目规划是文化项目运行管理中最为关键的一环。它不仅涉及到项目的总体目标、阶段性目标和具体任务的明确,还包括对项目时间表、资源分配及预算的详细安排。一个科学的项目规划可以有效地指导项目的实施,确保项目按计划进行,避免资源浪费和时间…

    2024年8月7日
    300
  • 新加坡项目管理模式是什么

    新加坡的项目管理模式是一种以结果为导向,注重团队协作的管理方式。这种模式的主要特点包括:以项目为中心,明确项目目标和预期成果;强调团队之间的沟通和协作,确保项目的顺利进行;关注风险管理,提前预防和解决可能出现的问题;重视质量管理,保证项目成果的质量和效益。其中,以项目为中心,明确项目目标和预期成果是…

    2024年8月7日
    400
  • 项目管理师需要学什么

    项目管理师需要掌握的知识和技能主要包括:项目管理理论、项目质量管理、项目风险管理、项目时间管理、项目成本管理、项目沟通管理、项目人力资源管理、项目采购管理、项目整合管理等。此外,还需要具备一定的领导力、沟通能力、决策能力、协调能力、解决问题的能力以及时间管理能力等。 接下来,我将详细介绍这些知识和技…

    2024年8月7日
    200

发表回复

登录后才能评论
注册PingCode 在线客服
站长微信
站长微信
电话联系

400-800-1024

工作日9:30-21:00在线

分享本页
返回顶部