当前位置: 首页 > news >正文

MySQL索引类型

  MySQL 是最流行的关系型数据库管理系统,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS (Relational Database Management System,关系数据库管理系统) 应用软件之一。

索引分类

  mysql的索引我们分为三大类来讲单列索引(普通索引,唯一索引,主键索引)、组合索引(联合索引/多列索引)。
  简单来说,索引就是一个指针,指向表里的数据。
  用索引的好处:索引通常与相应的表时分开保存的,目的是提高检索的性能。
  用索引的缺点:索引也会占据物理存储空间,可能比表本身还大,因此创建索引也要考虑存储空间。

普通索引

  没有任何限制,允许在定义索引的列中插入重复值和空值,创建一个单列索引的2种方式:

1]create index index_name on tbl_name(index_col_name)
2]alter table 表名 add index index_name on(index_col_name)

这里,create index表示创建一个索引,index_name表示索引的名称,on tbl_name表示要创建索引的表, index_col_name表示表中要创建索引的列

唯一索引

  索引列中的值必须是唯一的,但是允许为空值,也就是不允许具有索引值相同的行

CREATE UNIQUE CLUSTERED INDEX myclumn_cindex ON mytable(mycolumn)

这里,CLUSTERED INDEX是用来建立聚簇索引的关键字,此语句的意思是在表mytable上的mycolumn字段上创建一个名为myclumn_cindex的聚簇索引,且为唯一索引。

主键索引

是一种特殊的唯一索引,不允许有空值。简称主键,原文是PRIMARY KEY,由一个或多个列组成,用于唯一性标识数据表中的某一条记录。一个表可以没有主键,但最多只能有一个主键,并且主键值不能包含NULL。
实例:一般id作为表的主键

 PRIMARY KEY (`id`),

组合索引

  联合索引是指对表上的多个列进行索引,联合索引也是一棵B+树. 命名规则:表名_字段名

  • 1、需要加索引的字段,要在where条件中
  • 2、数据量少的字段不需要加索引
  • 3、如果where条件中是OR关系,加索引不起作用
  • 4、符合最左原则(where条件必须有联合索引的第一个字段)
CREATE TABLE `test` (`id` int(4) NOT NULL AUTO_INCREMENT,`name` varchar(10) NOT NULL,`age` varchar(2) NOT NULL,`sex` varchar(2) NOT NULL,`phone` varchar(12) NOT NULL,`email` varchar(25) NOT NULL,PRIMARY KEY (`id`),UNIQUE KEY `idx_name_age_sex` (`name`,`age`,`sex`) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT=0 DEFAULT CHARSET=utf8;

这就是联合索引:

 `idx_name_age_sex` (`name`,`age`,`sex`) 

使用组合索引时遵循最左前缀集合,这里由name、age和sex个字段构成的索引,索引行中就按name/age/sex的顺序存放,索引可以索引下面字段组合(name,age,sex)、(name,age)或者(name)或者(name,sex)。

http://www.lryc.cn/news/32969.html

相关文章:

  • 你了解HashMap吗?
  • 我一个女孩子居然做了十年硬件……
  • 【Linux】编译器gcc g++和调试器gdb的使用
  • 高效能自动化港口数字化码头智慧港航,中国人工智能企业CIMCAI世界港航人工智能领军者,成熟港口码头人工智能产品中国人工智能企业
  • HTTP协议(一)
  • 计算神经网络参数量Params、计算量FLOPs(亲测有效的3种方法)
  • sizeof与一维数组和二维数组
  • Spark UI
  • windows应用(vc++2022)MFC基础到实战(2)
  • 记一次反射型XSS
  • BUUCTF-[羊城杯 2020]Bytecode
  • 《Uniapp入门指南:从安装到打包的全流程》
  • 机器学习算法集成系统
  • scratch绘制雷达 电子学会图形化编程scratch等级考试三级真题和答案解析2022年9月
  • VRRP主备备份
  • 【软件逆向】软件破解?病毒木马?游戏外挂?
  • curl请求常用参数和返回码
  • 【STM32】进阶(一):抢占式优先级和响应式优先级(NVIC_PriorityGroupConfig)
  • LogCompilation后JIT输出文件格式解析
  • Linux学习第二十四节-Podman容器
  • 基于quartz实现定时任务管理系统
  • vue-element-admin:基于element-ui 的一套后台管理系统集成方案
  • KVM-7、KVM 虚拟机创建的几种方式
  • Hadoop三大框架之HDFS
  • 好好的系统,为什么要分库分表?
  • 多种调度模式下的光储电站经济性最优储能容量配置分析(Matlab代码实现)
  • 二分法(适用于任何题型!!!)
  • js常见的七种继承及实现
  • 案例分析之——理由Mybatis动态SQL实现复用
  • MCM 箱模型建模方法及大气 O3 来源解析实用干货