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

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: 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

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
mysql 的ReLog和BinLog区别
MySQL中的重做日志和二进制日志是确保数据库稳定性和可靠性的关键组件。重做日志主要用于事务的持久性和原子性,通过记录数据页的物理修改信息来恢复未提交的事务;而二进制日志记录SQL语句的逻辑变化,支持数据复制、恢复和审计。两者在写入时机、存储方式及配置参数等方面存在显著差异。
MySQL 和 Oracle 的区别?
本文对比了Oracle和MySQL数据库的多个方面。Oracle适用于大型数据库,支持高并发和大访问量,市场占有率为40%,安装占用空间较大,约3G;而MySQL适合中小型应用,是开源免费的,安装仅需152M。两者在主键生成、字符串处理、SQL语句、事务处理等方面存在差异。Oracle功能更为强大,尤其在企业级应用中表现突出,而MySQL则以简单易用见长。
MySQL 和 Oracle 的区别?
【MySQL进阶篇】存储引擎(MySQL体系结构、InnoDB、MyISAM、Memory区别及特点、存储引擎的选择方案)
MySQL的存储引擎是其核心组件之一,负责数据的存储、索引和检索。不同的存储引擎具有不同的功能和特性,可以根据业务需求 选择合适的引擎。本文详细介绍了MySQL体系结构、InnoDB、MyISAM、Memory区别及特点、存储引擎的选择方案。
【MySQL进阶篇】存储引擎(MySQL体系结构、InnoDB、MyISAM、Memory区别及特点、存储引擎的选择方案)
MySQL中为什么要使用索引合并(Index Merge)?
通过这些内容的详细介绍和实际案例分析,希望能帮助您深入理解索引合并及其在MySQL中的
174 10
MySQL引擎InnoDB和MyISAM的区别?
InnoDB是MySQL默认的事务型存储引擎,支持事务、行级锁、MVCC、在线热备份等特性,主索引为聚簇索引,适用于高并发、高可靠性的场景。MyISAM设计简单,支持压缩表、空间索引,但不支持事务和行级锁,适合读多写少、不要求事务的场景。
85 9
MySQL和Redis的区别
**MySQL和Redis的区别** MySQL和Redis都是流行的数据存储解决方案,但它们在设计、用途和特性上有显著区别。理解这些区别有助于选择合适的数据库来满足不同的应用需求。本文将详细介绍MySQL和Redis的区别,包括它们的架构、使用场景、性能和其他关键特性。 ### 一、基本概述 **MySQL**: MySQL是一个关系型数据库管理系统(RDBMS),使用结构化查询语言(SQL)进行数据管理。它支持事务、复杂查询和多种存储引擎,广泛应用于各种Web应用、企业系统和数据分析项目。 **Redis**: Redis是一个基于内存的键值数据库,通常被称为NoSQL数
299 4
mysql 的ReLog和BinLog区别
MySQL中的重做日志(Redo Log)和二进制日志(Binary Log)是两种重要的日志系统。重做日志主要用于保证事务的持久性和原子性,通过记录数据页的物理修改信息来恢复未提交的事务更改。二进制日志则记录了数据库的所有逻辑变化操作,用于数据的复制、恢复和审计。两者在写入时机、存储方式、配置参数和使用范围上有所不同,共同确保了数据库的稳定性和可靠性。
138 2
Docker Compose V2 安装常用数据库MySQL+Mongo
以上内容涵盖了使用 Docker Compose 安装和管理 MySQL 和 MongoDB 的详细步骤,希望对您有所帮助。
154 42
如何排查和解决PHP连接数据库MYSQL失败写锁的问题
通过本文的介绍,您可以系统地了解如何排查和解决PHP连接MySQL数据库失败及写锁问题。通过检查配置、确保服务启动、调整防火墙设置和用户权限,以及识别和解决长时间运行的事务和死锁问题,可以有效地保障应用的稳定运行。
97 25
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等