avatar

数据库索引

普通索引

  • 创建
1
CREATE INDEX indexname ON tablename(rowname));
  • 修改
1
ALTER tablename ADD INDEX indexname ON (rowname);
  • 删除
1
DROP INDEX indexname ON tablename;

唯一索引

索引列的值必须唯一 , 但允许有空值 .
如果是 组合索引 , 则 列值的 组合 必须唯一.

  • 创建
1
CREATE NIQUE INDEX indexname ON tablename(rowname));
  • 修改
1
ALTER tablename ADD NIQUE INDEX indexname ON (rowname);

主键索引

特殊的唯一索引. 一般是id

联合索引

由多个字段组成的索引, 叫做 组合索引 .
如果分别在 a b c 列 建立单列索引. 效率是远远低于 组合索引的.
组合索引(a,b,c)都有哪些排列组合?

组合索引 遵循“最左前缀”原则。简单的理解就是只从最左面的开始组合。并不是只要包含这三列的查询都会用到该组合索引.

1、组合索引字段无论顺序如何改变都会用到索引,前提是所有字段都在where条件上。
2、如果想要使用一个或者两个字段在where条件上,必须有组合索引里的第一个字段,但是与顺序无关,例如a,c或c,a,这种场景是可以命中索引的。但是,b,c或c,b这种是不会命中索引的。
3、如果组合索引存在范围查询,则组合索引可能会命中索引,这个跟B+Tree的叶子节点中存储的数据是否在当前的叶子节点中,即InnoDB存储引擎的最小存储单元——页,InnoDB页的大小默认是16k,可以通过参数查看页的默认大小:show global status like ‘innodb_page_size’;如果想要修改InnoDB页的大小,需要通过修改mysql源码才可以修改,找到源码文件(storage/innobase/include/univ.i),找到参数:UNIV_PAGE_SIZE,该参数必须是2的n次方,例如4k、8k、16k、32k、64k等等。
4、order by 只能使用a,才能用到索引。

设计索引注意事项

  • 索引不会包含有NULL值的列
    只要列中包含有NULL值都将不会被包含在索引中,复合索引中只要有一列含有 NULL值,那么这一列对于此复合索引就是无效的。所以我们在数据库设计时不要让字段的默认值为NULL。
  • 使用短索引
    对串列进行索引,如果可能应该指定一个前缀长度。例如,如果有一个CHAR(255)的列,如果在前10个或20个字符内,多数值是惟一的,那么就不要对整个列进行索引。短索引不仅可以提高查询速度而且可以节省磁盘空间和I/O操作
  • 索引列排序
    MySQL查询只使用一个索引,因此如果 where子句中已经使用了索引的话,那么order by中的列是不会使用索引的。因此数据库默认排序可以符合要求的情况下不要使用排序操作;尽量不要包含多个列的排序,如果需要最好给这些列创建复合索引
  • like 语句操作
    一般情况下不鼓励使用like操作,如果非使用不可,如何使用也是一个问题。like “%aaa%” 不会使用索引而like “aaa%”可以使用索引。
  • 不要在列上进行运算
    1
    select * from users where YEAR(adddate)<2007;
    将在每个行上进行运算,这将导致索引失效而进行全表扫描,因此我们可以改成
    1
    select * from users where adddate<‘2007-01-01’;
  • 不要使用NOT IN和<>操作
文章作者: L1uNan
文章链接: http://www.nanpy.top/posts/1442515a.html
版权声明: 本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 NanPy
打赏
  • 微信
    微信
  • 支付宝
    支付宝

评论