mysql索引 - mysql的表如何重新组织(或生成)索引?
问题描述
1,背景描述我有一个user表,表结构如下:索引如下:表中数据如下:
可以看到表中数据是按lastname排序的,这是因为在lastname, familyname, city上有一个多列索引,userid上的主键(索引)是后加的,所以userid是无序的。mysql当中有没有一种方法可以重新生成(或组织)索引,让select userid, lastname from user这条语句的查询结果默认是按userid排序?
注意:不是强制使用索引select userid, lastname, from user force index(primary),而是重新生成或组织索引(reorganize)。
4月29日更新
其实,我这里是想问mysql是不是有某个命令可以对表中已有的索引进行重新组织,就是在表经过一段时间的更新、删除、插入操作后,数据会发生变化(结构不变),那么表的索引也就相应的会发生各种变化(比如底层的碎片等),那么是不是有一种方法可以对这些索引重新组织或者重新生成,再不然就只能删除索引再重建索引。
5月2日更新我把最初提问的问题增加了删除线,开始的提问有些问题,特别是这儿的描述是错误的:“可以看到表中数据是按lastname排序的,这是因为在lastname, familyname, city上有一个多列索引,userid上的主键(索引)是后加的,所以userid是无序的可以看到表中数据是按lastname排序的,这是因为在lastname, familyname, city上有一个多列索引,userid上的主键(索引)是后加的,所以userid是无序的”,至于为什么是无序的,@clcx_1315已经回答了,而且他也指出即便重新组织(生成)索引,这句select userid, lastname from user也是无法实现让userid有序的。我百度了下,mysql当中好像没有专门用于重新生成或组织索引的命令,sql server数据库倒是有,感兴趣的朋友百度吧。
问题解答
回答1:mysql有optimize table的用法,但是同时也把表重组了。如果系统有明显的业务低峰期,删掉索引重建也是可以的。
回答2:这种情况是因为你主键外的其他列是一个复合索引,你查询的时候mysql就直接走索引表找到你的所有数据(mysql innodb普通索引会将主键信息一并存储),所以就是按照你索引首字段排序检索,他并不是按照录入磁盘顺序读取全表的,而主键则是按照磁盘录入顺序添加的,因此在磁盘上是顺序的,但是你读取的时候读的是索引表才会是不连续的要改变这种状况的话你重建表也是一样的,仍然会按lastname得索引排序,除非你按照lastname的顺序录入另外一个办法就是添加一个冗余字段,这时候再select全表的时候就不会走你的覆盖索引查询而是走全表扫描,当然就会主键渐顺序排列了。
回答3:我记得mysql也会根据你的索引情况自动对索引进行重建,具体根据什么也没查到。留待有缘人解答
相关文章:
1. nginx - 关于vue项目部署到ngnix后出现的问题2. javascript - h5分享链接到qq或者微信时有一个缩略图还有一些说明文字,这个要怎么去修改里面的图片和内容?3. angular.js - 在移动端web上如何解决输入法挡住文本框问题?4. 冒昧问一下,我这php代码哪里出错了???5. java - 怎么处理前台要展示,但是数据库表没有该字段的实体类冗余属性呢?6. docker api 开发的端口怎么获取?7. plupload 上传 android功能没有任何问题, ios 按钮却点不动8. 在windows下安装docker Toolbox 启动Docker Quickstart Terminal 失败!9. javascript - svg小白,想要在svg里面插入图片10. android - 哪位大神知道java后台的api接口的对象传到前端后输入日期报错,是什么情况?求大神指点