广告
返回顶部
首页 > 资讯 > 数据库 >Mysql基础02-约束
  • 361
分享到

Mysql基础02-约束

Mysql基础02-约束 2016-10-27 17:10:27 361人浏览 才女
摘要

约束与索引 概念 数据完整性(Data Integrity)是指数据的精确性(Accuracy)和可靠性(Reliability)。 实体完整性(Entity Integrity):例如,同一个表中,不能存在两条完全相同无法区分的记录

约束与索引

概念

数据完整性(Data Integrity)是指数据的精确性(Accuracy)和可靠性(Reliability)。

  • 实体完整性(Entity Integrity):例如,同一个表中,不能存在两条完全相同无法区分的记录

  • 域完整性(Domain Integrity):例如:年龄范围0-120,性别范围“男/女”

  • 引用完整性(Referential Integrity):例如:员工所在部门,在部门表中要能找到这个部门

  • 用户自定义完整性(User-defined Integrity):例如:用户名唯一、密码不能为空等

约束

  • 键约束:主键约束、外键约束、唯一键约束

  • Not NULL约束:非空约束

  • Check约束:检查约束

  • Default约束:默认值约束

  • 自增约束

约束(CONSTRAINTS)与索引(INDEX)

约束是用来对数据业务规则和数据完整性进行实施、维护。约束的作用范围仅限在当前数据库,是逻辑约束,不会因为设置约束而额外占用空间。

索引是一个单独、物理的存储在数据页上的数据库结构,它是表中一列或若干列值的集合和相应的指向表中数据值的物理标识数据页的逻辑指针清单(类似于新华字典的目录索引页)。可以大大提高查询速度。应该在键列、或其他经常要查询、排序、按范围查找的列上建立索引。

Mysql会在主键、唯一键、外键列上自动创建索引,其他列需要建立索引的话,需要手动创建。

其中主键删除,对应的索引也会删除

删除唯一键的方式是通过删除对应的索引来实现的

删除外键,外键列上的索引还在,如果需要删除,需要单独删除索引

查看某个表的约束

SELECT * FROM infORMation_schema.table_constraints WHERE table_name = "表名称";
或
SHOW CREATE TABLE 表名;

查看某个表的索引

SHOW INDEX FROM 表名称;

主键约束:primary key

主键分为单列主键和复合主键

主键的特点

(1)唯一并且非空(2)一个表只能有一个主键约束(3)主键约束名就叫做PRIMARY(4)创建主键会自动创建对应的索引,同样删除主键对应的索引也会删除。

建表时指定主键约束

create table 【数据名.】表名(
  字段名1 数据类型 primary key ,
  ....
);
或
create table 【数据名.】表名(
  字段名1 数据类型,
  ....,
  primary key(字段名1)
);
或
create table 【数据名.】表名(
  字段名1 数据类型,
  字段名2 数据类型,
  ....,
  primary key(复合主键字段列表)  #如果是复合主键,那么就需要在所有字段列表后面使用这种形式指定,不能在字段后面直接加primary key
);

建表后指定主键约束

alter table 表名称 add primary key (主键字段列表);

删除主键约束

alter table 表名称 drop primary key;

唯一键约束:unique key

唯一键约束特点:

(1)同一个表可以有多个唯一约束。(2)唯一约束可以是某一个列的值唯一,也可以多个列组合值的唯一。(3)mysql会给唯一约束的列上默认创建一个唯一索引。(4)删除唯一键只能通过删除对应索引的方式删除,删除时需要指定唯一键索引名

建表时指定唯一键约束

create table 【数据名.】表名(
  字段名1 数据类型 primary key ,
  字段名2 数据类型 unique key,
  ....
);

create table 【数据名.】表名(
  字段名1 数据类型 primary key ,
  字段名2 数据类型,
  字段名3 数据类型,
  ....,
  unique key(复合唯一字段列表)  #如果是复合唯一键,那么就需要在所有字段列表后面使用这种形式指定,不能在字段后面直接加unique key
);

建表后增加唯一键约束

alter table 表名称 addconstraint 约束名】 uniquekey】 (字段名列表);

#如果没有指定约束名,(字段名列表)中只有一个字段的,默认是该字段名,如果是多个字段的默认是字段名列表的第1个字段名。

删除唯一键约束

ALTER TABLE 表名称 DROP INDEX 唯一键约束名;

外键约束:foreign key

外键特点:

  • 外键约束是保证一个或两个表之间的参照完整性,外键是构建于一个表的两个字段或是两个表的两个字段之间的参照关系。

  • 在创建外键约束时,如果不给外键约束名称,默认名不是列名,而是自动产生一个外键名(例如 student_ibfk_1;),也可以指定外键约束名。

  • 当创建外键约束时,系统默认会在所在的列上建立对应的普通索引。但是索引名是列名,不是外键的约束名。

  • 删除外键时,关于外键列上的普通索引需要单独删除。

要求

  • 在从表上建立外键,而且主表要先存在。

  • 一个表可以建立多个外键约束

  • 从表的外键列,在主表中引用的只能是键列(主键,唯一键,外键),推荐引用主表的主键。

  • 从表的外键列与主表被参照的列名字可以不相同,但是数据类型必须一样

约束关系:约束是针对双方的

添加了外键约束后,主表的修改和删除受约束

添加了外键约束后,从表的添加和修改受约束

5个约束等级

  • Cascade方式:在父表上update/delete记录时,同步update/delete掉子表的匹配记录

  • Set null方式:在父表上update/delete记录时,将子表上匹配记录的列设为null,但是要注意子表的外键列不能为not null

  • No action方式:如果子表中有匹配的记录,则不允许对父表对应候选键进行update/delete操作

  • Restrict方式:同no action, 都是立即检查外键约束

  • Set default方式(在可视化工具sqlyog中可能显示空白):父表有变更时,子表将外键列设置成一个默认的值,但Innodb不能识别

如果没有指定等级,就相当于Restrict方式

建表时指定外键约束

create table 【数据名.】从表名(
  字段名1 数据类型 primary key ,
  字段名2 数据类型 【unique key】,
  ....,
  【constraint 外键约束名】 foreign key (从表字段) references 主表名(主表字段) 【on update 外键约束等级】【on delete 外键约束等级】
);

#外键只能在所有字段列表后面单独指定
#如果要自己命名外键约束名,建议 主表名_从表名_关联字段名_fk

建表后指定外键约束

alter table 从表名称 addconstraint 外键约束名】 foreign key (从表字段名) references 主表名(主表被参照字段名) 【on update xx】【on delete xx】;

删除外键约束

ALTER TABLE 表名称 DROP FOREIGN KEY 外键约束名;

#删除外键约束不会删除对应的索引

删除索引

ALTER TABLE 表名称 DROP INDEX 索引名;

非空约束:not null

规定某个字段不能为空

建表时指定非空约束

create table 【数据名.】表名(
  字段名1 数据类型 primary key ,
  字段名2 数据类型 【unique key】 【not null】,
  字段名2 数据类型 【not null】,
  ....,
);

建表后指定非空约束

ALTER TABLE 表名称 MODIFY 字段名 数据类型 NOT NULLdefault 默认值】;

#如果该字段原来设置了默认值约束,要跟着一起再写一遍,否则默认值约束会丢失

删除非空约束

ALTER TABLE 表名称 MODIFY 字段名 数据类型 【default 默认值】;

#如果该字段原来设置了默认值约束,要跟着一起再写一遍,否则默认值约束会丢失

默认值约束:default

建表时指定默认约束

create table 【数据名.】表名(
  字段名1 数据类型 primary key ,
  字段名2 数据类型 【unique key】 【not null】 【default 默认值】,
  字段名3 数据类型 【not null】 【default 默认值】,
  ....,
);

建表后指定默认值约束

ALTER TABLE 表名称 MODIFY 字段名 数据类型 【default 默认值】 【NOT NULL】;

#如果该字段原来设置了非空约束,要跟着一起再写一遍,否则非空约束会丢失

删除默认值约束

ALTER TABLE 表名称 MODIFY 字段名 数据类型 【NOT NULL】;

#如果该字段原来设置了非空约束,要跟着一起再写一遍,否则非空约束会丢失

检查约束,mysql暂不支持

自增约束:auto_increment

特点:

  • 一个表最多只能有一个自增长列

  • 自增长列必须是键列(主键列,唯一键列,外键列),并且要求非空。

  • 自增列必须是整数类型

  • InnoDB表的自动增长列可以手动插入,但是插入的值如果是空或者0,则实际插入的将是自动增长后的值。

建表时指定自增长

create table 【数据名.】表名(
  字段名1 数据类型 primary key auto_increment,
  字段名2 数据类型 【unique key】 【not null】 【default 默认值】,
  ....
);
或
create table 【数据名.】表名(
  字段名1 数据类型 primary key ,
  字段名2 数据类型 【unique key not null】 auto_increment,
  ....
);

建表后指定自增长

alter table 【数据名.】表名 modify 自增字段名 数据类型 auto_increment;

删除自增约束

alter table 【数据名.】表名 modify 自增字段名 数据类型;

添加数据时,如果某列有自增约束,怎么添加该字段的值

insert into 【数据库名.]表名称 values(值列表);#在值列表中,对应自增列可以赋值为null和0
insert into 【数据库名.]表名称(部分字段列表) values(值列表);#自增列在(部分字段列表)中不写就可以

添加数据时,如果某列有默认值约束,怎么添加、修改该字段的值

insert into 【数据库名.]表名称 values(值列表);#在值列表中,对应默认值列,如果想用默认值,用default

insert into 【数据库名.]表名称(部分字段列表) values(值列表);#对应默认值列,如果想用默认值,在(部分字段列表)中不写就可以

修改数据

update 【数据库名.]表名称 set 字段名1 = 值1, 字段名2 = 值2 。。。 【where 条件】; #对应默认值列,如果想用默认值,写字段名 = default就可以
您可能感兴趣的文档:

--结束END--

本文标题: Mysql基础02-约束

本文链接: https://www.lsjlt.com/news/3178.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Mysql基础02-约束
    约束与索引 概念 数据完整性(Data Integrity)是指数据的精确性(Accuracy)和可靠性(Reliability)。 实体完整性(Entity Integrity):例如,同一个表中,不能存在两条完全相同无法区分的记录 ...
    99+
    2016-10-27
    Mysql基础02-约束
  • 2020重新出发,MySql基础,MySql的约束
    @目录MySQL约束概述主键约束(PRIMARY KEY)在创建表时设置主键约束设置单字段主键设置联合主键在修改表时添加主键约束删除主键约束MySQL 主键自增长指定自增字段初始值外键约束在创建表时设置外键约束在修改表时添加外键约束删除外键...
    99+
    2020-11-22
    2020重新出发,MySql基础,MySql的约束 数据库入门 数据库基础教程 数据库 mysql
  • 【MySQL】唯一性约束【UNIQUE】从基础到就业
    唯一约束 【unique】: 用来限制某个字段/某列的值不能重复,唯一约束允许出现 多个空值 同一个表可以有多个唯一约束;唯一约束可以是某一个列的值唯一,也可以多个列组合的值唯一。 唯一性约束允许列值为空;在创建唯一约束的时候,如果不给唯一...
    99+
    2023-10-26
    mysql 数据库
  • 【MySQL基础教程】约束的介绍与使用
    前言 本文为 【MySQL基础教程】约束 相关知识,下边将对约束概述,约束演示,外键约束(包括:外键约束介绍、外键约束语法)等内容进行详尽介绍~ 📌博主主页:小新要变强 的主页 &#...
    99+
    2023-09-04
    mysql 数据库 java
  • MySQL约束
    约束 约束(constraint)概述 为什么要约束 为了保证数据完整性 什么是约束 对表中字段的(强制)限制 约束的分类 角度一:字段个数 单类约束,多列约束 角度二:约束的作用范围 / 定义位置 列级约束:将此约束声明在字段...
    99+
    2017-07-27
    MySQL约束
  • MySQL 约束
    概念: 对表中的数据进行限定,保证数据的正确性、有效性和完整性。 分类: 主键约束:primary key 非空约束:not null 唯一约束:unique 外键约束:foreign key 非空约束:not nu...
    99+
    2016-01-17
    MySQL 约束
  • 【MySQL】主键约束和外键约束
    目录 1、PRIMARY KEY 2、FOREIGN KEY 3、表的设计 3.1 一对一 3.2 一对多 3.3 多对多 1、PRIMARY KEY 上期我们讲述了 not null 和 unique 约束,而本期的第一个约束就...
    99+
    2023-09-01
    mysql 数据库
  • MySQL约束之默认约束default与零填充约束zerofill
    目录默认约束添加默认约束删除默认约束零填充约束 总结默认约束 mysql 默认值约束用来指定某列的默认值。 添加默认约束 方式1: <字段名> <数据类型> ...
    99+
    2022-07-07
    MySQL默认约束default MySQL零填充约束zerofill
  • MySQL——约束(constraint)
    本篇文章总结一下MySQL中的约束,为什么要使用约束?什么是约束以及约束的分类。数据完整性(Data Integrity)是指数据的精确性(Accuracy)和可靠性(Reliability)。它...
    99+
    2023-09-08
    数据库 mysql
  • MySQL 表约束
    约束概述 对数据表中数据的限制条件叫表的约束,目的是为了保证表中记录的完整和有效。例如非空、唯一等。 查看约束 1 通过查看建表语句 查看表中的约束 show create table tb_name; 2 通过检查约束表 查看...
    99+
    2015-05-19
    MySQL 表约束
  • MySQL主键约束和外键约束详解
    目录1、PRIMARY KEY2、FOREIGN KEY3、表的设计3.1 一对一3.2 一对多3.3 多对多1、PRIMARY KEY 上期我们讲述了 not null 和 unique 约束,而本期的第一个约束就是这...
    99+
    2023-03-13
    mysql主键约束和外键约束 mysql主键和外键
  • MySQL外键约束
    CASCADE:父表delete、update的时候,子表会delete、update掉关联记录; SET NULL:父表delete、update的时候,子表会将关联记录的外键字段所在列设为null,所以注意在设计子表时外键不能设为no...
    99+
    2020-02-25
    MySQL外键约束
  • 【MySQL】表的约束
    文章目录 1. 约束概念2. 空属性3. 默认值5. comment——列描述6. zerofill7. 主键8. 复合主键9. 自增长10. 唯一键关于唯一键的理解 11. 外键外键的理...
    99+
    2023-10-25
    mysql 数据库
  • 【mysql】—— 表的约束
    目录 序言 (一)空属性 (二)默认值 (三)列描述 (四)zerofill (五)主键 (六)自增长 (七)唯一键 (八)外键 总结 序言 真正约束字段的是数据类型,但是数据类型约束很单一,需要有一些额外的约束,更好的保证数据的合法...
    99+
    2023-08-31
    mysql 数据库
  • MySQL约束之默认约束default与零填充约束zerofill怎么实现
    本篇内容主要讲解“MySQL约束之默认约束default与零填充约束zerofill怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL约束之默认约束default与零填充约束zer...
    99+
    2023-07-02
  • MySQL主键约束和外键约束怎么设置
    这篇“MySQL主键约束和外键约束怎么设置”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“M...
    99+
    2023-03-13
    mysql
  • MySQL约束超详解
    目录MySQL约束操作1.非空约束 2.唯一约束3.主键约束4.外键约束5、级联MySQL约束操作 概念:对表中的数据进行限定,保证数据的正确性,有效性和完整性。 分类: ...
    99+
    2022-11-12
  • mysql-完整性约束
    约束条件与数据类型的宽度一样,都是可选参数作用:用于保证数据的完整性和一致性主要分为:PRIMARY KEY (PK)    #标识该字段为该表的主键,可以唯一的标识记录 FORE...
    99+
    2023-01-30
    完整性 mysql
  • MySQL基础|在Navicat中输入SQL语句步骤【含SQL语句约束规范】
    通常使用cmd进行SQL的编写,但是Navicat这个图形化工具在进行数据存储时更加清晰,因此现在在开发时是个更佳的选择。但输入SQL语句的地方新手却不容易找到 Navicat中输入SQL语句 ...
    99+
    2023-09-06
    MySQL Navicat SQL
  • 基于约束的SQL注入
    # 漏洞原理 在谈论这种攻击手法之前,首先我们需要了解几个关键知识点。 1、在SQL中执行字符串处理时,字符串末尾的空格符将会被删除。换句话说,‘nocoriander’和‘nocoriander    ’几乎是等效的 例如下列代码,和使用...
    99+
    2016-01-15
    基于约束的SQL注入 数据库入门 数据库基础教程 数据库 mysql
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作