问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

一道mysql的面试题,求大佬帮忙解答。

发布网友 发布时间:2022-04-22 03:19

我来回答

1个回答

热心网友 时间:2023-09-09 08:37





MySQL中数据类型有多种,如果你是一名DBA,正在按照优化的原则对数据类型进行严格的检查,但开发人员可能会选择他们认为最简单的方案,以加快编码 速度,或者选择最明显的选择,因此,你可能面临的都不是最佳的选择,如果可能的话,你应该尝试以通用准则来改变这些决定。

(1)避免使用NULL

NULL对于大多数数据库都需要特殊处理,MySQL也不例外,它需要更多的代码,更多的检查和特殊的索引逻辑,有些开发人员完全没有意识到,创建表时NULL是默认值,但大多数时候应该使用NOT NULL,或者使用一个特殊的值,如0,-1作为默认值。

(2)仅可能使用更小的字段

MySQL从磁盘读取数据后是存储到内存中的,然后使用cpu周期和磁盘I/O读取它,这意味着越小的数据类型占用的空间越小,从磁盘读或打包到内存的效 率都更好,但也不要太过执着减小数据类型,要是以后应用程序发生什么变化就没有空间了。修改表将需要重构,间接地可能引起代码的改变,这是很头疼的问题, 因此需要找到一个平衡点。

2、小心字符集转换

客户端或应用程序使用的字符集可能和表本身的字符集不一样,这需要MySQL在运行过程中隐含地进行转换,此外,要确定字符集如UTF-8是否支持多字节字符,因此它们需要更多的存储空间。

3、优化count(my_col)和count(*)

如果你使 用MyISAM表,在没有where子句的情况下使用count(*)速度是很快的,因为行数量的统计是非常精确的,因此MySQL不会一行一行地去找, 进而得出行数,如my_col列没有空值,那么和前面说的情况会一样,即count(my_col)速度也会很快。

如果有where子句时使用count( ),基本上就无法进行更多优化了,在where子句中超出了明显的索引列,对于复杂的where子句,只有使用覆盖索引才有用。

除了上面 的建议外,你还可以使用汇总表,它们让你可以对表的内容保持更新,你可以使用触发器,或者应用程序逻辑保持汇总表总是最新状态,或者定期运行一个批处理作 业保持填充最新的数据信息,如果你采用后者,你的信息将会非常接近,但不是精确的,依赖于批处理作业多久运行一次,这需要权衡应用程序对精确信息的需要, 和保持数据更新的系统开销,要在这二者之间找到一个平衡点。



4、优化子查询

遇到子查 询时,MySQL查询优化引擎并不是总是最有效的,这就是为什么经常将子查询转换为连接查询的原因了,优化器已经能够正确处理连接查询了,当然要注意的一 点是,确保连接表(第二个表)的连接列是有索引的,在第一个表上MySQL通常会相对于第二个表的查询子集进行一次全表扫描,这是嵌套循环算法的一部分。

5、优化UNION

在跨多个不同的数据库时使用UNION是一个有趣的优化方法,UNION从两个互不关联的表中返回数据,这就意味着不会出现重复的行,同时也必须对数据进行排序,我们知道排序是非常耗费资源的,特别是对大表的排序。

UNION ALL可以大大加快速度,如果你已经知道你的数据不会包括重复行,或者你不在乎是否会出现重复的行,在这两种情况下使用UNION ALL更适合。此外,还可以在应用程序逻辑中采用某些方法避免出现重复的行,这样UNION ALL和UNION返回的结果都是一样的,但UNION ALL不会进行排序。


面试题:谈谈如何优化MYSQL数据库查询
标签:

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
苹果电脑电池充不进电苹果电脑充不进去电是怎么回事 苹果电脑不充电没反应苹果电脑充电指示灯不亮充不了电怎么办 狗狗更加忠诚护家、善解人意,养一只宠物陪伴自己,泰迪能长多大... 描写泰迪狗的外形和特点的句子 国外留学有用吗 花钱出国留学有用吗 !这叫什么号 百万医疗赔付后是否可以续保 前一年理赔过医疗险还能续保吗? 医疗住院险理赔后还能购买吗? 梦见大师给自己算卦看手相说我以后越老越不好。还... 15个 MySQL 基础面试题,DBA 们准备好了吗 java 关于 mysql数据库的面试题,今天遇到一题面试... 梦见一个算命大师给我算命 在梦里很准的那种 算出... 数据库的面试会问什么样的问题? 华为4a手机闹钟没开却总显示闹钟标识是怎么回事? 面试mysql数据库dba时候会问什么问题 面试常问的数据库问题及答案 华为手机怎么设置闹钟提醒 mysql面试题 关于mysql面试题 数据库面试常问问题有哪些? 闹钟怎么设置每天提醒 Mysql 数据库面试问题 华为交换机系列划分 华为交换机有那些系列? 棠棣诗经翻译 卤味的制作方法 蓝牙耳机怎样的性能最好? 初二月考作文《桂花羔的味道》500字 海科传统大的POS机费率多少 海科融通的POS安全性怎么样,稳定吗? 电签版pos和其他的pos机有什么区别? 连帽卫衣和圆领套头卫衣的差别在哪里? 连帽卫衣如何搭配显得不幼稚且有范 电签版pos缺点有什么? 男士套头连帽卫衣什么牌子好 什么是套头卫衣 我是商户,想办一台海科融通的POS机,该怎么办理? 卫衣的卫字作何解释 灰色连帽卫衣怎样搭配 ? 海科•店掌柜电签版pos机靠不靠谱? 长款卫衣和短款卫衣你更喜欢哪一款? 卫衣是什么意思呀 刷卡机费率最低能有多少?如何办理最正规的 连帽衫该如何搭配才能显得时尚而不幼稚? 海科融通的POS怎么样 什么人不适合穿卫衣 中国唐朝至今服装的发展史 卫衣搭配什么裤子好看_卫衣怎么搭配裤子