我的编程空间,编程开发者的网络收藏夹
学习永远不晚

mysql优化技巧有何误区

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

mysql优化技巧有何误区

本文主要给大家介绍mysql优化技巧有何误区,文章内容都是笔者用心摘选和编辑的,具有一定的针对性,对大家的参考意义还是比较大的,下面跟笔者一起了解下mysql优化技巧有何误区吧。        

mysql优化技巧有何误区

        上面这条技巧粗略看一眼好像也没有什么问题。可事实是这样的吗?

        

        结论当然是否定的。且看实例分析:        

CREATE TABLE `t_auxiliary_info` (
  `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
  `ac_id` tinyint(3) unsigned NOT NULL COMMENT '分类ID',
  `name` varchar(250) NOT NULL DEFAULT '' COMMENT '名称',
  `number` smallint(6) unsigned NOT NULL DEFAULT '1' COMMENT '编号',
  `attr` varchar(500) NOT NULL DEFAULT '' COMMENT '属性',
  `fdbid` int(10) unsigned NOT NULL COMMENT '用户ID',
  `status` tinyint(1) unsigned NOT NULL DEFAULT '1' COMMENT '状态:1有效,0无效',
  `stock_type` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '存货类型:1库存商品,2原材料,3周转材料',
  PRIMARY KEY (`id`),#请注意这里的索引
  KEY `uniq_cid_acid` (`fdbid`,`ac_id`)
) ENGINE=InnoDB AUTO_INCREMENT=645101 DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC

    上面是一张普通的业务表,仔细看表中设置的索引:

  PRIMARY KEY (`id`),#主键索引
  KEY `uniq_cid_acid` (`fdbid`,`ac_id`)#联合索引        

        再使用上述的in 或not in 来实践以下,通过explain执行计划工具看看实际效果。(在这里为了公平起见,我不使用主键id,且in操作中的数据不是连续的。)        

select * 
from t_auxiliary_info 
where fdbid in('1000','1500','1234','5155','6789','3423','5368','245645');        
在上面的sql中,我们使用包含在联合索引`uniq_cid_acid`中的字段 `fdbid`作为搜索条件 

       见证奇迹的时刻到了。


mysql优化技巧有何误区    

        通过执行计划, 我们可以清晰的看到这条sql的检索类型为简单简单检索,属于范围查询,且已经使用到了索引  uniq_cid_acid,且没有全表扫描(扫描行数为2804,而本表中数据条数为645101)。

       

        由此可以得出结论:不是所有sql中的in查询会全表扫描。这里推翻了in会导致全表扫描的结论。


        那么在什么情况下,使用in操作一样可以使用到索引,不会全表扫描呢?

       答:  in的字段必须是带有索引的字段。

       ps:  in(...) 中的数据最好加上引号,即使字段类型是数字。


        在 看看not in       

select * 
from t_auxiliary_info 
where fdbid not in(1000,1500,1234,5155,6789,3423,5368,245645);

  

        真相在这里:

mysql优化技巧有何误区

not in确实会全表扫描。

看完以上关于mysql优化技巧有何误区,很多读者朋友肯定多少有一定的了解,如需获取更多的行业知识信息 ,可以持续关注我们的数据库栏目的。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

mysql优化技巧有何误区

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MySQL 优化技巧

优化数据库结构优化数据大小→ 减少磁盘写入和读取的数据量→ 在查询执行期间主动处理其内容时主内存较少→ 产生更小的索引,可以更快地处理表格列尽可能使用最高效(最小)的数据类型如果可能,将列声明为 NOT NULL → 更好地使用索引并消除
MySQL 优化技巧
2024-10-15

mysql join优化的技巧有哪些

优化MySQL JOIN操作可以提高查询性能,以下是一些常见的优化技巧:1. 使用合适的索引:确保参与JOIN的列都有合适的索引,这样可以加快连接操作的速度。可以使用EXPLAIN语句来分析查询计划,查看是否使用了索引。2. 尽量避免在JO
2023-10-23

Mysql索引优化技巧有哪些

Mysql索引优化的一些技巧包括:使用合适的数据类型:选择合适的数据类型来存储数据,避免使用过大或者不必要的数据类型,能够减小索引的大小,提高查询性能。设计合适的索引:根据查询需求和表的结构设计合适的索引,通常可以使用主键索引、唯一索引、组
Mysql索引优化技巧有哪些
2023-10-28

mysql sql优化的技巧有哪些

以下是一些MySQL SQL优化的常见技巧:使用索引:为频繁使用的列创建索引,以提高查询性能。可以使用EXPLAIN语句来分析查询语句是否使用了索引。优化查询语句:避免使用SELECT *,只选择所需的列。尽量避免使用子查询,可以使用JO
mysql sql优化的技巧有哪些
2024-04-09

MySQL查询优化技巧有哪些

使用索引:确保数据库表的字段都有合适的索引,这样可以加快查询的速度。避免查询所有字段:只选择需要的字段进行查询,避免查询过多无用字段。使用JOIN语句:合理使用JOIN语句可以减少查询次数,提高查询效率。避免使用SELECT :尽量避免使用
MySQL查询优化技巧有哪些
2024-04-09

mysql 数据库优化技巧

mysql 数据库优化 包括 a.表的设计合理化(符合3NF) b.添加适当索引(index[4种:普通索引 主键索引 唯一索引unique 全文索引]) c.分表技术(水平分割,垂直分割) d.读写[写:update/dele
2022-05-13

Linux系统中MySQL优化技巧有哪些

今天小编给大家分享一下Linux系统中MySQL优化技巧有哪些的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1.禁止操作系统
2023-06-28

MySQL 原理优化之Group By的优化技巧

今天来看看mysql 中如何多Group By 语句进行优化的。先创建tb_user 表如下:通过show index from tb_user; 命令查看表,没有存在任何的索引。执行如下代码,查看SQL 执行情况explailfyyP
2022-08-14

MySQL优化SQL语句的技巧

在面对不够优化、或者性能极差的SQL语句时,我们通常的想法是将重构这个SQL语句,让其查询的结果集和原来保持一样,并且希望SQL性能得以提升。而在重构SQL时,一般都有一定方法技巧可供参考,本文将介绍如何通过这些技巧方法来重构SQL。 一、
2022-05-24

mysql排序分页优化的技巧有哪些

以下是一些优化MySQL排序和分页的技巧:1. 使用索引:在排序和分页查询中,合适的索引可以大大提高查询性能。确保在排序和分页的列上添加索引。2. 使用覆盖索引:如果查询只需要从索引中获取数据而不需要访问表中的其他列,可以使用覆盖索引来提高
2023-10-23

编程热搜

目录