mysql索引相关理解
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索引相关理解的更多相关文章
- mysql 索引相关
引言: MYSQL由于其免费和开源的性质,在项目中用处广泛.大家都知道,一个MySQL数据库能够储存大量的数据,如果要在大量的数据中查找某一个数据,如果使用全表检索的话,即费时间又费力气,这时,就需要 ...
- 面试小知识:MySQL索引相关
前言 本模板主要是一些面试相关的题目,对于每一道问题,我会提供简单的解答,答案的来源主要是基于自己看了各方资料之后的理解,如果有错的,欢迎指点出来. 1. 什么是最左前缀原则? 以下回答全部是基于My ...
- mysql 索引相关知识
由where 1 =1 引发的思考 最近工作上被说了 说代码中不能用 where 1=1,当时觉得是应该可以用的,但是找不到什么理据, 而且mysql 语句优化这方面确实很薄弱 感觉自己mysql ...
- mysql索引相关
索引有主键索引.唯一索引.普通索引 单列索引,复合索引. 复合索引(a,b,c),可以理解是有三个索引,分别是a.b.c三个索引 前缀不是a的话,复合索引都不起作用,前缀用函数或者是范围,比如< ...
- mysql 索引相关问题
mysql中key .primary key .unique key 与index区别 https://blog.csdn.net/nanamasuda/article/details/5254317 ...
- 简单聊一下对MySQL索引的理解?
一.索引是什么? 索引是帮助MySQL高效获取数据的数据结构. 二.索引能干什么? 索引非常关键,尤其是当表中的数据量越来越大时,索引对于性能的影响愈发重要. 索引能够轻易将查询性能提高好几个数量级, ...
- Mysql索引深入理解
一. 引言 Mysql 我们平常用的很多,了解的很多,今天别的不说,直接说mysql的底层是什么,说到底层,就想到数据结构,那么,mysql的数据结构是什么呢? 是B + tree .那么数据库中的 ...
- 面试官:小伙子,你给我说一下你对MySQL索引的理解吧
一.索引是什么? 索引是帮助MySQL高效获取数据的数据结构. 二.索引能干什么? 索引非常关键,尤其是当表中的数据量越来越大时,索引对于性能的影响愈发重要.索引能够轻易将查询性能提高好几个数量级,总 ...
- 【逐步完善】MySql索引相关
在表中对某个字段添加索引: alter table tablename add index (columnname);
随机推荐
- office套件
一.PDF模块 使用PyPDF2模块 pip install PyPDF2 1.1 从PDF读取数据 直接读取,并打印出来.但是这种打印存在一个问题,不能中文字符 import PyPDF2 impo ...
- int argc,char *argv[]
main()函数是操作系统调用的,argc表示传入参数的个数,argv[]表示传入的参数. argv[0]表示exe文件所在的路径,所以argc默认为1. main函数的参数是可以通过dos窗口传入, ...
- 【http】HTTP请求方法 之 OPTIONS
OPTIONS方法是用于请求获得由Request-URI标识的资源在请求/响应的通信过程中可以使用的功能选项.通过这个方法,客户端可以在采取具体资源请求之前,决定对该资源采取何种必要措施,或者了解服务 ...
- PHP strip_tags() 函数的作用和用法
strip_tags()函数可以轻松实现从字符串中去除 HTML 和 PHP 标记. 使用方法: trip_tags ( string $str [, string $allowable_tags ] ...
- ios 第3天
在手动引用计数中 每一次调用 retain retainCount 就会加一 每一次release retainCount就会减一 当retainCount 为零时 就会free (p) ; ...
- jquery表单验证插件 jquery.form.js-转
来自:http://www.cnblogs.com/luluping/archive/2009/04/15/1436177.html Form插件,支持Ajax,支持Ajax文件上传,功能强大,基本满 ...
- PostgreSQL 系统参数调整及并行设置(转)
转自:https://yq.aliyun.com/teams/5 OS 准备 # yum -y install coreutils glib2 lrzsz sysstat e4fsprogs xfsp ...
- java事务(一)
Java中事务处理的基本方法与原理,包含以下文章: (一)Java事务处理的基本问题 (二)失败的案例 (三)丑陋的案例 (四)成功的案例(自己实现一个线程安全的TransactionManager) ...
- Android中破解应用签名校验的后续问题处理方案(闪退和重启现象以及无效问题)
一.前言 之前已经写了一个爆破签名校验的工具kstools,很多同学也在使用,但是也反馈了不少问题,之前一篇文章也介绍了,关于爆破之后第三方登录问题修复,这篇我们在综合说明一下一些后遗症问题,关于ks ...
- 那些年提交AppStore审核踩过的坑
此文刚刚上了CocoaChina的首页:那些年提交AppStore审核踩过的坑 欢迎围观,谢谢大家支持. //add by 云峰小罗,2016.08.04 做iOS开发近5年了,每次提交版本时不可谓 ...