索引是一种特殊的文件(InnoDB数据表上的索引是表空间的一个组成部分),它们包含着对数据表里所有记录的引用指针。

普通索引(由关键字KEY或INDEX定义的索引)的唯一任务是加快对数据的访问速度。

普通索引允许被索引的数据列包含重复的值。如果能确定某个数据列将只包含彼此各不相同的值,在为这个数据列创建索引的时候就应该用关键字UNIQUE把它定义为一个唯一索引。

也就是说,唯一索引可以保证数据记录的唯一性。

主键,是一种特殊的唯一索引,在一张表中只能定义一个主键索引,主键用于唯一标识一条记录,使用关键字 PRIMARY KEY 来创建。 索引可以覆盖多个数据列,如像INDEX(columnA, columnB)索引,这就是联合索引。

主键分为复合主键和联合主键

复合主键就是指你表的主键含有一个以上的字段组成 。 例如; create table test ( name varchar(19), id number, value varchar(10), primary key (id,name) ) 上面的id和name字段组合起来就是你test表的复合主键 (若其一为单索引字段时,左边的id才会有索引) 它的出现是因为你的name字段可能会出现重名,所以要加上ID字段这样就可以保证你记录的唯一性 一般情况下,主键的字段长度和字段数目要越少越好

联合主键,顾名思义就是多个主键联合形成一个主键组合,体现在联合。 (主键原则上是唯一的,别被唯一值所困扰。) 索引可以极大的提高数据的查询速度,但是会降低插入、删除、更新表的速度,因为在执行这些写操作时,还要操作索引文件。 简单的例子 主键A跟主键B组成联合主键 主键A跟主键B的数据可以完全相同(困扰吧,没关系),联合就在于主键A跟主键B形成的联合主键是唯一的。

下例主键A数据是1,主键B数据也是1,联合主键其实是11,这个11是唯一值,绝对不充许再出现11这个唯一值。(这就是多对多关系) 主键A数据 主键B数据 1      1 2      2 3      3 主键A与主键B的联合主键值最多也就是 11 12 13 21 22 23 31 32 33

mysql唯一索引和联合索引的区别_mysql中,索引,主键,唯一索引,联合索引的区别...相关推荐

  1. mysql主键约束和外键约束的作用_MySQL中的主键约束和外键约束

    1.主键约束 表通常具有包含唯一标识表中每一行的值的一列或一组列. 这样的一列或多列称为表的主键 (PK),用于强制表的实体完整性. 由于主键约束可保证数据的唯一性,因此经常对标识列定义这种约束. 如 ...

  2. mysql中主键的用法_MySQL中的主键以及设置其自增的用法教程

    1.声明主键的方法:您可以在创建表的时候就为表加上主键,如: CREATE TABLE tbl_name ([字段描述省略...], PRIMARY KEY(index_col_name)); 也可以 ...

  3. mysql 隐式主键_MySQL中复合主键性能的缺点

    我们有一个表,该表具有由三个字段组成的复合主键(在MySQL 5.1中是这样). 该表上每秒有近200个插入和200个选择,并且表的大小约为100万行,并且还在不断增加. 我的问题是:"复合 ...

  4. SqlServer为什么自动在主键上建立聚集索引

    微软推荐为每一个表建立一个聚集索引,但是由于sqlserver简单易用,而且很多人并不了解聚集索引,非聚集索引这些东西,所以如果sqlserver不在主键上建立聚集索引的话,可能会导致大部分的表都是堆 ...

  5. MySQL中的主键约束和外键约束

    1.主键约束 表通常具有包含唯一标识表中每一行的值的一列或一组列. 这样的一列或多列称为表的主键 (PK),用于强制表的实体完整性. 由于主键约束可保证数据的唯一性,因此经常对标识列定义这种约束. 如 ...

  6. oracle主键 唯一索引的区别,Oracle 主键、唯一键与唯一索引的区别

    一般,我们看到术语"索引"和"键"交换使用,但实际上这两个是不同的.索引是存储在数据库中的一个物理结构,键纯粹是一个逻辑概念.键代表创建来实施业务规则的完整性约 ...

  7. mysql索引的使用及优化方法_MySQL中索引和优化的用法总结

    1.什么是数据库中的索引?索引有什么作用? 引入索引的目的是为了加快查询速度.如果数据量很大,大的查询要从硬盘加载数据到内存当中. 2.InnoDB中的索引原理是怎么样的? InnoDB是MySQL的 ...

  8. mysql主键创建非聚集索引_什么是聚集索引,非聚集索引,索引覆盖,回表,索引下推...

    聚集索引 我们先建如下的一张表 CREATE TABLE `student` (`id` int(11) NOT NULL AUTO_INCREMENT COMMENT '学号',`name` var ...

  9. mysql主键索引需要创建_mysql主键还需要建立索引吗?

    mysql主键不需要建立索引,主键具备索引的功能:当创建或设置主键的时候,mysql会自动添加一个与主键对应的唯一索引,不需要再做额外的添加.数据库管理系统对于主键会自动生成唯一索引,所以主键是一个特 ...

最新文章

  1. zblog文件大小超出,上传成功但插入不了
  2. 能跑TensorFlow,能唱KTV,这是国产车吉利的智能系统和背后的芯片
  3. sparse double型矩阵转为full矩阵
  4. .NET Core 中有等价的 HttpContext.Response.Cache 吗?
  5. 在AWS Elastic MapReduce上运行PageRank Hadoop作业
  6. eclipse 安装git
  7. str split函数 php,怎么在php中利用str_split函数分割字符串
  8. 【无一时】的意思和解释
  9. 叶子的离开,是因为风的追求,还是树的不挽留
  10. 如何将Java源代码转换为HTML页面
  11. 【转】鼠标右键菜单设置大全
  12. vb查询mysql数据库_怎么在vb程序中查找数据库信息并显示
  13. SVN 忽略不需要提交的文件
  14. filter java 意思_在JAVA中filter有什么作用?
  15. android 颜色透明度16进制换算
  16. 微信小程序商城源码独立版/公众号/H5/DIY装修/营销/直播/拼团/秒杀/前端vue全开源代码
  17. 关于自动布局(Autolayout)
  18. 匿怨而友其人,左丘明耻之,丘亦耻之。我不是圣人,我假装什么都没发生。
  19. 经典差动放大器应用电路详解
  20. ULTRON — 360基于Flink的实时数仓平台

热门文章

  1. FMX Windows下无边框窗口处理
  2. 瞎几把写的QQ注册页面
  3. {前辈的经验}[经验技巧] 程序员道路的经验之谈
  4. 教你视频的快进和慢动作效果制作
  5. 解决Input输入中文重复出现拼音
  6. 距离向量DV与链路状态LS算法的区别
  7. 路遇险阻并不可怕,达到终点就是英雄
  8. 设计模式(现在只总结了常用的8种)
  9. Silverlight全开源工作流设计器
  10. Werkzeug学习笔记