1.索引是高效获取数据的数据结构,

2.唯一索引,索引值不重复unique

create unique index 索引名 on 表名(字段)

alter table 表名 add unique index 索引名(字段)

3.主键索引 唯一索引的一种 primary key

create table 表名(id int not null primary auto_increament)type=myism

4.单列索引和多列索引(复合索引)

复合索引用最左前缀的概念

5.聚簇索引

索引中键值的逻辑顺序决定表中的物理顺序,聚簇索引决定表中的物理顺序

innodb主键就是聚簇索引,myisam没有聚簇索引

6.show index from 表名 查看表的索引

key_name ->索引类型 column_name ->索引字段

cardinality ->索引基数 平均数组值=基数/总行数 越接近1表示越可能用到索引

index_type -> 索引结构 fulltext b+tree

7.b-tree性质

m阶b-tree

ki表示关键字 k1<k2<k3<k4<k5<k6<k7<k8<kn  左子结点关键字的值<右子节点关键字的值

pi表示指向子节点指针 左指针指向左节点 右指针指向右节点 p1指向值<k1<p2指向值<k2

所有关键字必须唯一(myisam和innodb必须建主键的原因)

节点-》 每个节点最多有 m 个子节点

根节点若非是叶子节点最少有两个子节点

非根非叶子节点至少有m/2个子节点

关键字-》根节点关键字个数1-(m-1)

非根非叶子节点关键字(m/2-1) - (m-1)

关键字数 +1 =指针数

b+tree是b-tree的变体 关键字数 = 指针数

8.myisam的索引结构

myisam索引采用b+tree结构存储数据,索引指针指向键值地址,地址存储数据

myisam的索引和数据是分离的 索引保存在 表名.myi 数据保存在 biaoming.myd文件

9.innodb索引结构

innodb索引结构跟myisam有明显区别 索引和数据存储在一起

支持事务-》三行隐藏数据列 db_row_id db_row_ptr db_row_id

主键索引保存数据 辅助索引保存主键的值 -》索引主键索引越短越好,这样辅助索引也就越小

10.myisam和innodb比较

myisam支持全文索引,顺序存储,索引叶子节点保存数据地址,辅助索引和主键差不多

innodb支持事务,主键节点直接保存数据,辅助索引保存主键索引的值

myisam键值分离 索引载入内存 innodb 键值保存在一起,索引和数据一起载入innodb缓冲池

11.mysql的优化

表数据类型

-》尽量小-》使用能正确表示的最短的数据类型存储-》减少磁盘空间 内存 cpu使用

-》避免使用null count统计列时会忽略null的行 不会用到索引

-》尽量使用整型 int(1)和int(11)是一样的

sql优化

-》复合索引的最左前缀原则, where字段要和索引顺序保持一致

-》复合索引会用到非第一列出现范围的一列 之后不会用到索引 第一列出现范围也不会用到索引

-》or会遍历全表不会用到索引

mysql索引相关理解的更多相关文章

  1. mysql 索引相关

    引言: MYSQL由于其免费和开源的性质,在项目中用处广泛.大家都知道,一个MySQL数据库能够储存大量的数据,如果要在大量的数据中查找某一个数据,如果使用全表检索的话,即费时间又费力气,这时,就需要 ...

  2. 面试小知识:MySQL索引相关

    前言 本模板主要是一些面试相关的题目,对于每一道问题,我会提供简单的解答,答案的来源主要是基于自己看了各方资料之后的理解,如果有错的,欢迎指点出来. 1. 什么是最左前缀原则? 以下回答全部是基于My ...

  3. mysql 索引相关知识

    由where 1 =1 引发的思考 最近工作上被说了 说代码中不能用 where 1=1,当时觉得是应该可以用的,但是找不到什么理据, 而且mysql 语句优化这方面确实很薄弱   感觉自己mysql ...

  4. mysql索引相关

    索引有主键索引.唯一索引.普通索引 单列索引,复合索引. 复合索引(a,b,c),可以理解是有三个索引,分别是a.b.c三个索引 前缀不是a的话,复合索引都不起作用,前缀用函数或者是范围,比如< ...

  5. mysql 索引相关问题

    mysql中key .primary key .unique key 与index区别 https://blog.csdn.net/nanamasuda/article/details/5254317 ...

  6. 简单聊一下对MySQL索引的理解?

    一.索引是什么? 索引是帮助MySQL高效获取数据的数据结构. 二.索引能干什么? 索引非常关键,尤其是当表中的数据量越来越大时,索引对于性能的影响愈发重要. 索引能够轻易将查询性能提高好几个数量级, ...

  7. Mysql索引深入理解

    一.  引言 Mysql 我们平常用的很多,了解的很多,今天别的不说,直接说mysql的底层是什么,说到底层,就想到数据结构,那么,mysql的数据结构是什么呢? 是B + tree .那么数据库中的 ...

  8. 面试官:小伙子,你给我说一下你对MySQL索引的理解吧

    一.索引是什么? 索引是帮助MySQL高效获取数据的数据结构. 二.索引能干什么? 索引非常关键,尤其是当表中的数据量越来越大时,索引对于性能的影响愈发重要.索引能够轻易将查询性能提高好几个数量级,总 ...

  9. 【逐步完善】MySql索引相关

    在表中对某个字段添加索引: alter table tablename add index (columnname);

随机推荐

  1. MyCAT 命令行监控

    MyCAT  命令行监控 9066端口 ,用mysql命令行连接 Mysql –utest –ptest –P9066 show @@help 可显示所有相关管理命令

  2. laravel中composer镜像服务的方式

    系统全局配置:即将配置信息添加到Composer的全局配置文件config.json中. 单个项目配置:将配置信息添加到某个项目的composer.json文件中. 例1:修改Composer的全局配 ...

  3. USB events thread - failed to set priority

    ubuntu + openni + nite,出现 Warning:USB events thread - failed to set priority xn::ImageGenerator imag ...

  4. 循环中的let和const声明

    一.循环中的let声明 每次循环的时候let声明都会创建一个新变量i,并将其初始化为i的当前值,所以循环内部创建的每个函数都能得到属于他们的i的副本. 最初的: for (var i = 0 ; i ...

  5. [Shell]bash的良好编码实践

    最好的bash脚本不仅可以工作,而且以易于理解和修改的方式编写.很多好的编码实践都是来自使用一致的变量名称和一致的编码风格.验证用户提供的参数是否正确,并检查命令是否能成功运行,以及长时间运行是否能保 ...

  6. [置顶] flume高并发优化——(15)中间件版本升级

    在系统平稳运行一年的基础上,为提供更好的服务,现针对java,kafka,flume,zk,统一进行版本升级,请各位小伙伴跟着走起来,不要掉队啊! 名称 老版本号 新版本号 jdk 1.7.0_25 ...

  7. 一张图说明HTTPS 握手过程

  8. Weinre(pc调试手机页面)

         Weinre是一款基于Web Inspector(Webkit)的远程调试工具,借助于网络,可以在PC上直接调试运行在移动设备上的远程页面,中文意思是远程Web检查器,有了Weinre,在P ...

  9. TCP、UDP详解

    OSI 计算机网络7层模型 TCP/IP四层网络模型 传输层提供应用间的逻辑通信(端到端),网络层提供的是主机到主机的通信,传输层提供的是可靠服务. TCP 中常说的握手指的是:连接的定义和连接的建立 ...

  10. redis常用配置参数解析

    本文主要总结一下redis常用的配置参数的用法: 以下参数决定redis运行方式,默认前台运行,修改为yes可以让redis以后台守护进程方式运行 daemonize no 以下参数指定redis的p ...