zoukankan      html  css  js  c++  java
  • MySQL

    primary key PK unique key 总结

    1. primary key = unique + not null 主键不能为空每个字段值都不重复,unique可以为空,非空字段不重复
    2. unique 一个或者多个字段定义,primary key 单字段主键或多字段联合主键
    3. primary key一个表只能有一个,unique一个表可以有多个
    4. 逻辑设计上primary key用来作记录标识,unique用来保证唯一性,但是在他们创建时都会去相应创建一个unique index,可以用来做sql优化。

    key PK index 总结

    创建primary key时,自动创建主键索引。创建unique key的时候,自动创建唯一索引:

    1. key有两个作用:约束+索引index
    2. index只有一个作用:辅助查询

    Key的两个作用

    mysql的key和index多少有点令人迷惑,单独的key和其它关键词结合的key(primary key)实际表示的意义是不同,这实际上考察对数据库体系结构的了解的。

    key 是数据库的物理结构,它包含两层意义和作用,

    • 一是约束(偏重于约束和规范数据库的结构完整性)
    • 二是索引(辅助查询用的)

    包括primary key, unique key, foreign key 等。

    primary key 

    primary key 有两个作用,一是约束作用(constraint),用来规范一个存储主键和唯一性,但同时也在此key上建立了一个主键索引;    

                              PRIMARY KEY 约束:唯一标识数据库表中的每条记录;

                                                                     主键必须包含唯一的值;

                                                                     主键列不能包含 NULL 值;

                                                                     每个表都应该有一个主键,并且每个表只能有一个主键。(PRIMARY KEY 拥有自动定义的 UNIQUE 约束)

    unique key

    unique key 也有两个作用,一是约束作用(constraint),规范数据的唯一性,但同时也在这个key上建立了一个唯一索引;

    UNIQUE 约束:唯一标识数据库表中的每条记录。
                                                        UNIQUE 和 PRIMARY KEY 约束均为列或列集合提供了唯一性的保证。
                                                        (每个表可以有多个 UNIQUE 约束,但是每个表只能有一个 PRIMARY KEY 约束)

    foreign key

    foreign key 也有两个作用,一是约束作用(constraint),规范数据的引用完整性,但同时也在这个key上建立了一个index;

    可见,mysql的key是同时具有constraint和index的意义,这点和其他数据库表现的可能有区别。

    (至少在Oracle上建立外键,不会自动建立index),因此创建key也有如下几种方式:
    (1)在字段级key方式建立, 如 create table t (id int not null primary key);
    (2)在表级constraint方式建立,如create table t(id int, CONSTRAINT pk_t_id PRIMARY key (id));
    (3)在表级key方式建立,如create table t(id int, primary key (id));

    其它key创建类似,但不管那种方式,既建立了constraint,又建立了index,只不过index使用的就是这个constraint或key。

    Index的作用

    index是数据库的物理结构,它只是辅助查询的,它创建时会在另外的表空间(mysql中的innodb表空间)以一个类似目录的结构存储。索引要分类的话,分为前缀索引、全文本索引等;
    因此,索引只是索引,它不会去约束索引的字段的行为(那是key要做的事情)。如,create table t(id int,index inx_tx_id (id));

    Index的分类

    索引分类,分为:

    1. 主键索引(必须指定为“PRIMARY KEY”,没有PRIMARY Index)、
    2. 唯一索引(unique index,一般写成unique key)、
    3. 普通索引(index,只有这一种才是纯粹的index)

    最重要的也就是,不管如何描述,需要理解index是纯粹的index,还是被当作key(如:unique index、unique key和primary key),若当作key时则会有两种意义或起两种作用。

    参考

    雪山上的蒲公英 https://www.cnblogs.com/zjfjava/p/6922494.html

  • 相关阅读:
    妹妹
    小猴和北极熊
    盛趣->盛大
    运维
    操之过急
    修马路
    博人传
    醉酒
    【跨域】SpringBoot跨域,拦截器中,第一次获取的请求头为NULL,发送两次请求的处理方式
    【Linux】Linux安装Tomcat
  • 原文地址:https://www.cnblogs.com/frankcui/p/12006515.html
Copyright © 2011-2022 走看看