数据库的约束有哪些

数据库的约束有: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)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023年1月6日 上午5:59
下一篇 2023年1月6日 上午6:30

相关推荐

  • 质量管理究竟是做什么的

    质量管理是指在质量方面指挥和控制组织的协调的活动。 质量管理,通常包括制定质量方针和质量目标以及质量策划、质量控制、质量保证和质量改进。不同的公司,担任此职务的人工作有所不同。质量管理是“在质量方面指挥和控制组织的协调的活动”。 一、质量管理的定义 质量管理是指在质量方面指挥和控制组织的协调的活动。…

    2023年1月1日
    68200
  • 版本管理的主要内容包括什么

    版本管理主要内容包括:1、版本的前期规划;2、在版本开发时;3、在版本发布后。在版本开发前通过建立版本号标识,明确版本目标,制定好版本上线需求内容,设计好发布策略,可以让产品功能和质量尽可能地符合用户的预期。 1、在版本开发前 通过建立版本号标识,明确版本目标,制定好版本上线需求内容,设计好发布策略…

    2022年11月30日
    18700
  • 如何搭建wiki在线文档

    搭建wiki在线文档的步骤:一、选择Wiki软件;二、安装Wiki软件;三、配置Wiki;四、编写文档;五、分享文档。首先需要选择一个Wiki软件。一些流行的Wiki软件包括MediaWiki, DokuWiki和Confluence。需要考虑个人自身的需求以及团队的技术水平来选择合适的软件。 一、…

    2023年3月21日
    600
  • iaas特点优势有哪些

    iaas特点:1、租赁;2、自助服务;3、动态缩放;4、服务等级;5、许可;6、计量。iaas优势:1、节约成本;2、按需扩展;3、灵活性好;4、专注于业务增长;5、可靠性高;6、支持的应用广泛。使用iaas时企业不需要购置硬件,节约成本。 一、iaas特点 1、租赁 当你使用IaaS服务,购买服务…

    2023年1月15日
    5100
  • C#中字符串可以使用可变大小的内存,为什么数字不能

    原因有:1、字符串的可变性;2、字符串的优化;3、数字的不可变性;4、数字的优化。在C#中,字符串是由字符组成的数组,可以通过字符串的长度属性来获取其长度,也可以使用索引来访问字符串中的每个字符。 1、字符串的可变性 在C#中,字符串是由字符组成的数组,可以通过字符串的长度属性来获取其长度,也可以使…

    2023年2月28日
    1200
  • JVM虚拟机和编译器作用有什么区别

    JVM虚拟机和编译器作用的区别是:编译器是用来编译java源代码的,以.java为后缀的java源代码必须编译以后才能运行;java虚拟机是java代码的运行环境也就是说被编译器编译以后的java代码在java虚拟机上运行。 JVM虚拟机和编译器作用的区别是:编译器是用来编译java源代码的,以.j…

    2023年2月13日
    3000
  • 服务营销理论有哪些

    服务营销理论包含以下几点:1、服务产品;2、服务渠道;3、服务价格;4、服务促销;5、服务人员;6、服务过程;7、有形展示。服务营销最早是从市场营销中衍生出来的一种营销方式,在传统的4P理论上增加3P,形成了7P理论。 1、服务产品 服务产品的内涵包括提供什么样的服务,提供什么程度的服务,提供质量如…

    2022年11月6日
    10300
  • 三种实现servlet的方式有什么区别

    三种实现servlet的方式有的区别在于:1、实现Servlet接口;2、通过继承GenericServlet;3、通过继承HttpServlet。Servlet并不是专门用于处理Http请求的。Servlet接口是定义在javax.servlet包中,HTTPServlet 使用一个 HTML 表…

    2023年2月13日
    1700
  • audio in是什么接口

    audio in接口是音频输入接口,可以输入其他的音源来放音,比如说MP3、手机、DVD等。音频输入接口可将计算机、录像机等的音频信号输入进来,通过自带扬声器播放,并且可以接入任何支持的音频设备。 一、audio in接口 audio in接口是音频输入接口,可以输入其他的音源来放音,比如说MP3、…

    2023年3月17日
    700
  • 消息代理与RPC框架有什么区别和联系

    区别是:消息代理又称消息队列,是面向队列的,主要维护客户端和服务端之间的消息,消息队列是在消息的传输过程中保存消息的容器。RPC是远程过程调用的缩写形式。RPC框架也是有消息队列的,只不过不需要使用消息队列的东西,只需要调用就好。 消息代理 消息代理,又称消息队列,是面向队列的,主要维护客户端和服务…

    2023年2月15日
    2100

发表回复

登录后才能评论
联系我们
关注微信
关注微信
分享本页
返回顶部
PingCode 比 Jira 更好用的研发管理工具。免费试用         文章及站点合作,请添加微:All-FeiFei