目录
一、关系型数据库设计规则
二、数据完整性和约束与索引的概念
三、约束的应用
首页 数据库 mysql教程 MySQL约束与索引概念是什么

MySQL约束与索引概念是什么

May 26, 2023 am 10:04 AM
mysql

一、关系型数据库设计规则

遵循ER模型和三范式

  • E entity 代表实体的意思 对应到数据库当中的一张表

  • R relationship 代表关系的意思

三范式:

1、列不能拆分

2、唯一标识

3、关系引用主键

具体体现

  • 将数据放到表中,表再放到库中。

  • 一个数据库中可以有多个表,每个表都有一个名字,用来标识自己。表名具有唯一性。

  • 表具有一些特性,这些特性定义了数据在表中如何存储,类似java和python 中 “类”的设计。

  • 表由列组成,我们也称为字段。数据表的设计实际上是对各个字段的含义进行设计和描述。在创建数据表时,需要为每个字段指定数据类型,定义它们的数据长度和命名。每个字段类似java 或者python中的“实例属性”。

  • 表中的数据是按行存储的,一行即为一条记录。每一行类似于java或python中的“对象”。

MySQL约束与索引概念是什么

二、数据完整性和约束与索引的概念

1、数据完整性(Data Integrity)是指数据的精确性(Accuracy)和可靠性(Reliability。这个要点旨在防止数据库中存在不符合语义规定的数据,同时避免因错误信息的输入输出而导致无效操作或错误信息。

数据的完整性要从以下四个方面考虑:

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

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

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

  • 用户自定义完整性(User-defined Integrity):例如:用户名唯一、密码不能为空等,本部门经理的工资不得高于本部门职工的平均工资的5倍。

2、约束(CONSTRAINTS)

约束是用来对数据业务规则和数据完整性进行实施、维护。约束的作用范围仅限在当前数据库,约束可以被当做数据库对象来处理,它们具有名称和关联模式,是逻辑约束,不会因为设置约束而额外占用空间。

3、索引(INDEX)

索引是一个单独、物理的存储在数据页上的数据库结构,它是表中一列或若干列值的集合和相应的指向表中数据值的物理标识数据页的逻辑指针清单(类似于新华字典的目录索引页)。索引的存在会增加数据库的存储空间,也会使插入、修改数据的时间开销变多(因为插入和修改数据时,索引也要随之变动),但是可以大大提高查询速度。因此应该在键列、或其他经常要查询、排序、按范围查找的列上建立索引,而对于在查询中很少使用和参考的列、修改非常频繁的列,值很少的列(例如性别只有男和女)等列上不应该创建索引。

MySQL约束与索引概念是什么

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

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

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

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

三、约束的应用

1、查看某个表的约束和索引

1

2

3

4

5

6

#查看某个表的约束

SELECT * FROM information_schema.table_constraints WHERE table_name = '表名称';

SHOW CREATE TABLE 表名;

#查看某个表的索引

SHOW INDEX FROM 表名称;

登录后复制

2、主键约束:primary key

(1)主键分为单列主键和复合主键(复合主键不建议使用,因为复合主键违背三范式。):

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

#单个字段设置主键

create table t_user(

    id int primary key,

    username varchar(20),

    password varchar(20)

);

create table t_user(

    id int,

    username varchar(20),

    password varchar(20),

    primary key(id)

);

#多个字段设置联合主键

drop table t_user;

create table t_user(

    id int,

    username varchar(20),

    password varchar(20),

    primary key(id,username)

);

#了解

#在建表后指定主键约束

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

#删除主键约束

alter table 表名称 drop primary key;

登录后复制

主键的特点:

  • 1、一张表中只能有一个主键

  • 2、设置为主键的字段的值唯一且非空

  • 3、若主键有多个字段组成,此时不能在字段后面设置主键,应该在所有字段后面使用"primary key(字段,字段)"

  • 4、联合主键中,组成主键的每个字段都非空,可以单独重复,但是不能同时重复

  • 5、创建主键会自动创建对应的索引,同样删除主键对应的索引也会删除。

3、自增约束:auto_increment

1

2

3

4

5

6

7

8

9

create table t_user(

    id int primary key auto_increment,

    username varchar(20),

    password varchar(20)

);

#建表后指定自增长列

alter table [数据库.]表名 modify 自增字段名 数据类型 auto_increment;

#删除自增约束

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

登录后复制

自增约束的特点:

要求一个表中只有一个主键为自增长类型的字段,该字段必须为整型且不能为空。通常只在主键上设置键约束,如主键约束、唯一键约束、外键约束

2、设置为自增的字段,从1开始自增;每次添加数据,都会在该字段最大值的基础上+1

3、使字段自增的方式:

  • 如果是空或者0,则实际插入的将是自动增长后的值。

  • a> insert into t_user(username,password) values(‘admin’,‘123456’);

  • b> insert into t_user values(null,‘root’,‘123456’); (推荐使用)

  • c> insert into t_user values(0,‘root’,‘123456’);

4、唯一键约束:unique key

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

create table t_user(

    id int primary key auto_increment,

    username varchar(20) unique key,

    password varchar(20) unique key

);

create table t_user(

    id int primary key auto_increment,

    username varchar(20),

    password varchar(20),

    unique key(username,password)

);

#在建表后增加唯一键约束

alter table 表名称 add 【constraint 约束名】 unique key (字段名列表);

#如果没有指定约束名,(字段名列表)中只有一个字段的,默认是该字段名,如果是多个字段的默认是字段名列表的第1个字段名。也可以通过show index from 表名;来查看

#删除唯一键约束

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

#注意:如果忘记名称,可以通过“show index from 表名称;”查看

登录后复制

唯一键约束的特点:

  • 1、设置唯一键约束的字段值唯一,但是可以为null

  • 2、一张表可以设置多个唯一键约束,也可以设置联合唯一键,即多个字段设置一个唯一约束,但是不能使用"unique key"写在字段后设置,必须写在所有字段后,使用"unique key(字段,字段)"

  • 3、联合唯一键要求组成唯一约束的字段可以单独重复,不能同时重复

  • 4、 MySQL会给唯一约束的列上默认创建一个唯一索引。

  • 5、删除唯一键只能通过删除对应索引的方式删除,删除时需要指定唯一键索引名

5、非空约束:not null

1

2

3

4

5

6

7

8

9

10

11

create table t_user(

    id int primary key auto_increment,

    username varchar(20) unique key not null,

    password varchar(20)

);

#在建表后指定某个字段非空

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

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

#取消某个字段非空

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

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

登录后复制

非空约束的特点:

设置为非空约束的字段的值不能为null

6、默认值约束:default

1

2

3

4

5

6

create table t_user(

    id int primary key auto_increment,

    username varchar(20) unique key not null,

    password varchar(20),

    gender char not null default '男'

);

登录后复制

添加数据时使用默认值的方式:

不为该字段赋值或使用关键字default

  • insert into t_user(username,password) values(‘root’,‘123’);

  • insert into t_user values(null,‘admin123’,‘123’,default);

  • insert into t_user values(null,‘admin’,‘123’,null); //此方式不可以,会为该字段赋值为null

7、外键约束:foreign key

表关系:

1、一对一

2、多对一,在多的一方引用一的主键

  • student(sid,sname,age,sex,cid)–clazz(cid,cname,location)

3、一对多,在多的一方引用一的主键

  • clazz(cid,cname,location)–student(sid,sname,age,sex,cid)

4、多对多

  • user(uid,username,password)

  • order(oid,create_time,total_count,total_amount,status,user_id)

  • order_goods(id,oid,gid)

  • goods(gid,gname,price,sales,stock)

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

create table t_dept(

    id int primary key auto_increment,

    name varchar(20)

);

create table t_emp(

    id int primary key auto_increment,

    name varchar(20),

    age int,

    gender char,

    dept_id int,

    foreign key(dept_id) references t_dept(id)

    #外键只能在所有字段列表后面单独指定

);

#在建表后指定外键约束

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

#删除外键约束

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

#查看某个表的约束名

SELECT * FROM information_schema.table_constraints WHERE table_name = '表名称';

SHOW CREATE TABLE 表名;

#删除外键约束不会删除对应的索引,如果需要删除索引,需要用ALTER TABLE 表名称 DROP INDEX 索引名;

#查看索引名 show index from 表名称;

登录后复制

(1)外键特点

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

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

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

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

(2)要求

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

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

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

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

(3)约束关系:约束是针对双方的

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

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

  • 在从表上建立外键,要求主表必须存在

  • 删除主表时,要求从表先删除,或将从表中外键引用该主表的关系先删除

(4)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方式

8、检查约束:check

检查约束,mysql暂不支持

1

2

3

4

5

6

7

8

9

10

11

12

13

create table stu(

    sid int primary key,

    sname varchar(20),

    gender char check ('男'or'女')

);

insert into stu values(1,'张三','男');

insert into stu values(2,'李四','妖');

使用枚举类型解决如上问题:

create table stu(

    sid int primary key,

    sname varchar(20),

    gender enum ('男','女')

);

登录后复制

以上是MySQL约束与索引概念是什么的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
2 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

PHP 的大数据结构处理技巧 PHP 的大数据结构处理技巧 May 08, 2024 am 10:24 AM

大数据结构处理技巧:分块:分解数据集并分块处理,减少内存消耗。生成器:逐个产生数据项,无需加载整个数据集,适用于无限数据集。流:逐行读取文件或查询结果,适用于大文件或远程数据。外部存储:对于超大数据集,将数据存储在数据库或NoSQL中。

如何在 PHP 中使用 MySQL 备份和还原? 如何在 PHP 中使用 MySQL 备份和还原? Jun 03, 2024 pm 12:19 PM

在PHP中备份和还原MySQL数据库可通过以下步骤实现:备份数据库:使用mysqldump命令转储数据库为SQL文件。还原数据库:使用mysql命令从SQL文件还原数据库。

如何优化 PHP 中的 MySQL 查询性能? 如何优化 PHP 中的 MySQL 查询性能? Jun 03, 2024 pm 08:11 PM

可以通过以下方式优化MySQL查询性能:建立索引,将查找时间从线性复杂度降至对数复杂度。使用PreparedStatements,防止SQL注入并提高查询性能。限制查询结果,减少服务器处理的数据量。优化连接查询,包括使用适当的连接类型、创建索引和考虑使用子查询。分析查询,识别瓶颈;使用缓存,减少数据库负载;优化PHP代码,尽量减少开销。

如何使用 PHP 插入数据到 MySQL 表中? 如何使用 PHP 插入数据到 MySQL 表中? Jun 02, 2024 pm 02:26 PM

如何将数据插入MySQL表中?连接到数据库:使用mysqli建立与数据库的连接。准备SQL查询:编写一个INSERT语句以指定要插入的列和值。执行查询:使用query()方法执行插入查询,如果成功,将输出一条确认消息。

如何在 PHP 中使用 MySQL 存储过程? 如何在 PHP 中使用 MySQL 存储过程? Jun 02, 2024 pm 02:13 PM

要在PHP中使用MySQL存储过程:使用PDO或MySQLi扩展连接到MySQL数据库。准备调用存储过程的语句。执行存储过程。处理结果集(如果存储过程返回结果)。关闭数据库连接。

如何使用 PHP 创建 MySQL 表? 如何使用 PHP 创建 MySQL 表? Jun 04, 2024 pm 01:57 PM

使用PHP创建MySQL表需要以下步骤:连接到数据库。创建数据库(如果不存在)。选择数据库。创建表。执行查询。关闭连接。

如何修复 MySQL 8.4 上的 mysql_native_password 未加载错误 如何修复 MySQL 8.4 上的 mysql_native_password 未加载错误 Dec 09, 2024 am 11:42 AM

MySQL 8.4(截至 2024 年的最新 LTS 版本)中引入的主要变化之一是默认情况下不再启用“MySQL 本机密码”插件。此外,MySQL 9.0完全删除了这个插件。 此更改会影响 PHP 和其他应用程序

oracle数据库和mysql的区别 oracle数据库和mysql的区别 May 10, 2024 am 01:54 AM

Oracle数据库和MySQL都是基于关系模型的数据库,但Oracle在兼容性、可扩展性、数据类型和安全性方面更胜一筹;而MySQL则侧重速度和灵活性,更适合小到中等规模的数据集。①Oracle提供广泛的数据类型,②提供高级安全功能,③适合企业级应用程序;①MySQL支持NoSQL数据类型,②安全性措施较少,③适合小型到中等规模应用程序。

See all articles