mysql—数据库优化——如何选择合适的索引
索引的分类:
普通索引;
唯一索引;
主键索引:特殊的唯一索引,唯一且不能有null值;
全文索引:全文索引用来对表中的文本域(char, varchar, text)进行索引
全文索引针对myisam存储引擎
explain select * from articles where match(title,body) against('database');
【会使用全文索引】
================================================
什么情况下使用索引?
使用了索引,会有什么影响?
1,占用磁盘空间;
2,插入、修改、删除操作变慢;
所以,索引使用场景:
1,不是频繁变化的的多个值;
2,该字段不是唯一的几个值;
3,where条件中经常被使用的字段;
4,排序字段
================
什么情况下索引会失效?
1,复合索引,不是使用第一部分就不会使用索引;
2,like查询,如果百分号%开头不会使用索引;
……
3,条件中有or,有条件没有使用索引,即使其中有条件带索引也不会使用;
换言之,就是要求使用的所有字段,都必须单独使用时也能使用索引;
4,如果类类型是字符串,一定要要用引号引起来;
5,如果预估使用全表扫描比使用索引快;
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!