首页 / MYSQL / mysql 索引作用范围
mysql 索引作用范围
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了mysql 索引作用范围,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1753字,纯文字阅读大概需要3分钟。
内容图文
上面索引的名字可以自己命名
使用索引(在where 之后加上索引,提高传效率)
select * from tbl_student where stu_name=?
总之:
索引在经常查询的字段上面建立索引。
利用index对查询进行优化(index可以避免对表的一个全面扫描)
原理:
当以某个字段建立一个索引的时候,数据库就会生成一个索引页,当我们查询数据时,Oracle会先查索引页,这样就能够很快的查找到要找的记录。
注意:
如果表的列很少,不适合建索引。
当执行过多次的insert,delete,update后,会出现索引碎片,影响查询速度,我们应该对索引进行重组,其方法如下:
drop index index_name;
create index index_name on table(column)
其实,就是删除掉索引,重新再建立索引。
拓展:
对于创建的多列索引,只要查询条件使用了最左边的列,索引一般就会使用。
对于使用like的查询,查询如果是 “%aaa” 不会使用到索引,‘aaa%’会使用到索引。
下列的表将不会使用索引:
1、如果条件中有or,即使其中有条件带索引也不会使用。
2、对于多列索引,不是使用的第一部分,则不会使用索引。
3、like查询是以%开头
4、如果列类型是字符串,那一定要再条件中将数据使用引号引起来,否则不使用索引。(添加是,字符串必须“)
5、如果MySQL估计使用全表扫描比使用索引快,则不使用索引。
alter table account add index my_index(login,name)
//login就是最左边的列,name就是右边的列
如果表中有复合索引,索引作用在多列上,此时我们注意:对于创建的多列索引,只要查询条件使用了最左边的列,索引一般会被使用。
此时:
select * from account where name="timchen"
由于使用的是右侧的列,此时索引是不会生效的,如何知道呢?
添加explain 此时possible_key的值是为空的。
但是当我们使用左侧的列是,explain的值不为空。
转载
timchen525的专栏
mysql 索引作用范围
标签:bsp acl 类型 account tar 创建索引 不能 适合 pos
本文系统来源:http://www.cnblogs.com/zo11o/p/7102495.html
内容总结
以上是互联网集市为您收集整理的mysql 索引作用范围全部内容,希望文章能够帮你解决mysql 索引作用范围所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。