Mysql碎片整理:约束

140 阅读2分钟

开启掘金成长之旅!这是我参与「掘金日新计划 · 12 月更文挑战」的第9天,点击查看活动详情

约束的概念

约束是指在修改表内容时遵循的某种规则。

主键

主键的作用:用来保证一列或一组列中的指是唯一的,主键设定后不再被改动。

主键可以用来唯一标识某一行的内容,通常用在WHERE语句中,搭配其它SQL语句。

三种方式定义主键

  1. 可视化界面(省略)
  2. 创建表的时候指定,关键字PRIMARY KEY
CREATE TABLE user
(
    user_id INTEGER NOT NULL PRIMARY KEY,
    name VARCHAR(25) NOT NULL
)
  1. 修改表结构时,指定主键
ALTER TABLE 表名 ADD PRIMARY KEY (列名);

外键

外键的作用:保证引用的完整性。它的好处通过一个例子可以理解:

  • A表是订单表(order_id,user_id),它有两个字段,第一个是主键,第二给是外键(属于B表的主键)
  • B表是用户表(user_id)

当订单产生的时候,如果没有外键关系,则A表中的user_id可能为空,但这明显不符合逻辑。所以在设计关系型数据库的时候,当两个表存在字段上的关联时,就应该设置外键。

其它好处还有:防止意外删除;或者级联删除

三种方式定义外键

  1. 可视化界面(省略)
  2. 创建表的时候指定,关键字REFERENCES
CREATE TABLE orders
(
    order_id INTEGER NOT NULL PRIMARY KEY,
    user_id INTEGER NOT NULL REFERENCES user(user_id)
)
  1. 修改表结构时,指定外键关系,指定A表中的外键。
ALTER TABLE A表名
ADD CONSTRAINT FOREIGN KEY(A表的字段) REFERENCES B表(B表的字段);

外键的删除规则

因为外键是两个表的关联,它对数据之间的依赖性又增强了,所以在删除数据的时候,如果有外键时,在删除的规则上就有讲究了。它需要再配合上ON关键字。

ALTER TABLE A表名
ADD CONSTRAINT FOREIGN KEY(A表的字段) REFERENCES B表(B表的字段)
ON DELETE xxx

这里xxx就是我们需要制定的规则,规则有:

父表表示原始的B表,而子表是定义外键的A表。

  1. CASCADE:从父表删除或更新且自动删除或更新子表中匹配的行。(删除(更新)B中的内容,A表内容自动被删除(更新))
  2. SET NULL:从父表删除或更新行,并设置子表中的外键列为NULL。使用该选项,必须保证子表列没有指定NOT NULL。(不常用)
  3. RESTRICT:拒绝对父表的删除或更新操作。
  4. NO ACTION:与RESTRICT相同(默认)。

这里常用的是1,3,4。而4是默认的。