文章详情页
mysql普通索引效率
浏览:214日期:2022-06-14 13:04:28
问题描述
select * from post where zhuanid = 0 and catid <> 10 and empty =0;1、本SQL语句:唯一性太差的还要建索引吗 比如empty 就是0或者1 catid一共就8个数 但表数据量是上百万
2、还有2个及2个以上条件查询的 必须要将全部字段建一个复合索引吗
3、如果如上三个字段分别建了一个普通索引 这个and会使用索引吗
对多个查询条件的索引概念比较模糊 但我现在数据库的CPU非常高
问题解答
回答1:具体问题具体分析。唯一性太差的没必要创建独立索引。建议创建联合索引,并调整查询语句。(zhanid,catid,empty)。语句改写成 zhuanid = 0 and catid in(a,b,c,d,e) and empty =0
回答2:<> 这个是不是干掉索引了?
负向查询条件:NOT、!=、<>、!<、!>、NOT IN、NOT LIKE等,会导致全表扫描
回答3:select 值得怀疑一下是否是必要的,分别索引的话,mysql优化器会有自己的判。你这个可以走覆盖索引
相关文章:
1. android glide asbitmap 在baseadpter中的问题2. spring-mvc - spring-session-redis HttpSessionListener失效3. python - flask post提交timestamp不能作为参数,这是为什么?4. node.js - express框架,设置浏览器从缓存中读取静态文件,只有js从缓存中读取了,css还有一些图片为何没有从缓存中读取?5. javascript - 如何获取未来元素的父元素在页面中所有相同元素中是第几个?6. java - Spring boot 读取 放在 jar 包外的,log4j 配置文件,系统有创建日志文件,不写入日志信息。7. javascript - QQ第三方登录的问题8. 前端 - @media query 使用出现的问题?9. python 计算两个时间相差的分钟数,超过一天时计算不对10. linux - redis连接池应用在一万并发下时连接数只有2?
排行榜

网公网安备