MySQL - key、primary key、unique key、index 区别(二)

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
云数据库 RDS MySQL Serverless,价值2615元额度,1个月
简介: MySQL - key、primary key、unique key、index 区别(二)

一、key & primary key 区别

CREATE TABLE wh_logrecord (   
    logrecord_id int(11) NOT NULL auto_increment,   
    user_name varchar(100) default NULL,   
    operation_time datetime default NULL,   
    logrecord_operation varchar(100) default NULL,   
    PRIMARY KEY (logrecord_id),   
    KEY wh_logrecord_user_name (user_name)   
);

解析:

KEY wh_logrecord_user_name (user_name)

本表的user_name字段与wh_logrecord_user_name表user_name字段建立外键

括号外是建立外键的对应表,括号内是对应字段

类似还有 KEY user(userid)

当然,key未必都是外键


总结:

Key是索引约束,对表中字段进行约束索引的,都是通过primary foreign unique等创建的。常见有foreign key,外键关联用的。

KEY forum (status,type,displayorder)  # 是多列索引(键) 
KEY tid (tid)                         # 是单列索引(键)。

如建表时: KEY forum (status,type,displayorder)

select * from table group by status,type,displayorder 是否就自动用上了此索引,

而当 select * from table group by status 此索引有用吗?

key的用途:主要是用来加快查询速度的。


CREATE TABLE `admin_role` (  
  `adminSet_id` varchar(32) NOT NULL,  
  `roleSet_id` varchar(32) NOT NULL,  
  PRIMARY KEY (`adminSet_id`,`roleSet_id`),  
  KEY `FK9FC63FA6DAED032` (`adminSet_id`),  
  KEY `FK9FC63FA6C7B24C48` (`roleSet_id`)  
) ENGINE=InnoDB DEFAULT CHARSET=utf8;  

主键,两个列组合在一起,是唯一的,内建唯一性索引,并且不能为NULL。

另外,两个Key定义,相当于分别对这两列建立索引。

innodb:

primary key:主键聚集索引

key:普通索引


二、KEY与INDEX区别

KEY通常是INDEX同义词。如果关键字属性PRIMARY KEY在列定义中已给定,则PRIMARY KEY也可以只指定为KEY。

这么做的目的是与其它数据库系统兼容。

PRIMARY KEY是一个唯一KEY,此时,所有的关键字列必须定义为NOT NULL。

如果这些列没有被明确地定义为NOT NULL,MySQL应隐含地定义这些列。一个表只有一个PRIMARY KEY。


区别 :

Key即键值,是关系模型理论中的一部份,比如有主键(Primary Key),外键(Foreign Key)等,用于数据完整性检否与唯一性约束等。

而Index则处于实现层面,比如可以对表的任意列建立索引,那么当建立索引的列处于SQL语句中的Where条件中时,就可以得到快速的数据定位,从而快速检索。

至于Unique Index,则只是属于Index中的一种而已,建立了Unique Index表示此列数据不可重复,猜想MySQL对Unique Index类型的索引可以做进一步特殊优化吧。

于是乎,在设计表的时候,Key只是要处于模型层面的,而当需要进行查询优化,则对相关列建立索引即可。

另外,在MySQL中,对于一个Primary Key的列,MySQL已经自动对其建立了Unique Index,无需重复再在上面建立索引了。



三、mysql中UNIQUE KEY和PRIMARY KEY有什么区别

1,Primary key的1个或多个列必须为NOT NULL,如果列为NULL,在增加PRIMARY KEY时,列自动更改为NOT NULL。

而UNIQUE KEY 对列没有此要求

2,一个表只能有一个PRIMARY KEY,但可以有多个UNIQUE KEY

3,主键和唯一键约束是通过参考索引实施的,如果插入的值均为NULL,则根据索引的原理,全NULL值不被记录在索引上,所以插入全NULL值时,可以有重复的,而其他的则不能插入重复值。


alter table t add constraint uk_t_1 unique (a,b); 
insert into t (a ,b ) values (null,1);     # 不能重复 
insert into t (a ,b ) values (null,null);  # 可以重复 


四、使用 UNIQUE KEY


CREATE TABLE `secure_vulnerability_warning` (   
  `id` int(10) NOT NULL auto_increment,   
  `date` date NOT NULL,   
  `type` varchar(100) NOT NULL,   
  `sub_type` varchar(100) NOT NULL,   
  `domain_name` varchar(128) NOT NULL,   
  `url` text NOT NULL,   
  `parameters` text NOT NULL,   
  `hash` varchar(100) NOT NULL,   
  `deal` int(1) NOT NULL,   
  `deal_date` date default NULL,   
  `remark` text,   
  `last_push_time` datetime default NULL,   
  `push_times` int(11) default '1',   
  `first_set_ok_time` datetime default NULL,   
  `last_set_ok_time` datetime default NULL,   
  PRIMARY KEY  (`id`),   
  UNIQUE KEY `date` (`date`,`hash`)   
) ENGINE=InnoDB  DEFAULT CHARSET=utf8; 

UNIQUE KEY的用途:主要是用来防止数据插入的时候重复的。

1,创建表时

CREATE TABLE Persons   
(   
    Id_P int NOT NULL,   
    LastName varchar(255) NOT NULL,   
    FirstName varchar(255),   
    Address varchar(255),   
    City varchar(255),   
    UNIQUE (Id_P)   
);

如果需要命名 UNIQUE 约束,以及为多个列定义 UNIQUE 约束,请使用下面的 SQL 语法:


CREATE TABLE Persons   
(   
    Id_P int NOT NULL,   
    LastName varchar(255) NOT NULL,   
    FirstName varchar(255),   
    Address varchar(255),   
    City varchar(255),   
    CONSTRAINT uc_PersonID UNIQUE (Id_P,LastName)   
);

2,当表已被创建时,如需在 "Id_P" 列创建 UNIQUE 约束,请使用下列 SQL:


ALTER TABLE Persons   
ADD UNIQUE (Id_P);

如需命名 UNIQUE 约束,并定义多个列的 UNIQUE 约束,请使用下面的 SQL 语法:

ALTER TABLE Persons   
ADD CONSTRAINT uc_PersonID UNIQUE (Id_P,LastName);  

3,撤销 UNIQUE 约束

如需撤销 UNIQUE 约束,请使用下面的 SQL:


ALTER TABLE Persons   
DROP INDEX uc_PersonID;  

转自:https://www.cnblogs.com/zjfjava/p/6922494.html#top

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
2天前
|
存储 关系型数据库 MySQL
MySQL的优化利器⭐️Multi Range Read与Covering Index是如何优化回表的?
本文以小白的视角使用通俗易懂的流程图深入浅出分析Multi Range Read与Covering Index是如何优化回表
|
3天前
|
关系型数据库 MySQL
MySQL union和union all的用法详解和区别
MySQL union和union all的用法详解和区别
10 0
|
4天前
|
存储 SQL 关系型数据库
mysql中MyISAM和InnoDB的区别是什么
mysql中MyISAM和InnoDB的区别是什么
12 0
|
4天前
|
关系型数据库 MySQL
MySQL 的 union 和union all 的区别
【5月更文挑战第4天】MySQL 的 union 和union all 的区别
21 7
|
10天前
|
SQL 关系型数据库 MySQL
【MySQL】DQL-分组查询-语法&where与having的区别&注意事项&可cv例题语句
【MySQL】DQL-分组查询-语法&where与having的区别&注意事项&可cv例题语句
【MySQL】DQL-分组查询-语法&where与having的区别&注意事项&可cv例题语句
|
11天前
|
关系型数据库 MySQL 数据库
MySQL8报错:Public Key Retrieval is not allowed
MySQL8报错:Public Key Retrieval is not allowed
|
11天前
|
存储 关系型数据库 MySQL
MySQL 格式化日期函数 DATE_FORMAT(), FROM_UNIXTIME() 和 UNIX_TIMESTAMP() 之间区别
MySQL 格式化日期函数 DATE_FORMAT(), FROM_UNIXTIME() 和 UNIX_TIMESTAMP() 之间区别
|
1天前
|
关系型数据库 MySQL 数据库
docker MySQL删除数据库时的错误(errno: 39)
docker MySQL删除数据库时的错误(errno: 39)
|
1天前
|
关系型数据库 MySQL 数据库连接
用Navicat备份Mysql演示系统数据库的时候出:Too Many Connections
用Navicat备份Mysql演示系统数据库的时候出:Too Many Connections
|
2天前
|
存储 Oracle 关系型数据库
oracle 数据库 迁移 mysql数据库
将 Oracle 数据库迁移到 MySQL 是一项复杂的任务,因为这两种数据库管理系统具有不同的架构、语法和功能。
15 0