在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
送分题面试官:有操作过Linux吗? 我:有的呀 面试官:我想查看内存的使用情况该用什么命令 我: 面试官:那你说一下用free命令都可以看到啥信息 我:那,如下图所示 可以看到内存以及缓存的使用情况
面试官:那你知道怎么清理已使用的缓存吗(buff/cache) 我:em… 不知道 面试官: 我:(送分题,内心大喜)好处大大的有,清理出缓存我们就有更多可用的内存空间, 就跟pc上面xx卫士的小火箭一样,点一下,就释放出好多的内存 面试官:em…, 回去等通知吧 再谈SQL Join面试官:换个话题,谈谈你对join的理解 我: 好的(再答错就彻底完了,把握住机会) 回顾SQL中的
面试官:在项目开发中如果需要使用 我: 分为两种情况,数据规模小的,数据规模大的。 面试官: 然后? 我:对于
面试官:可以总结为 我:是的 面试官: 为什么? 缓冲区我: 在执行join语句的时候必然要有一个比较的过程 面试官: 是的 我:逐条比较两个表的语句是比较慢的,因此我们可以把两个表中数据依次读进一个 如下图所示 面试官: 除此之外呢? 一个大前提我:任何项目终究要上线,不可避免的要产生数据,数据的规模又不可能太小 面试官: 是这样的 我:大部分数据库中的数据最终要保存到 以MySQL的InnoDB引擎为例
验证 我:这意味着我们有多少表要连接就需要读多少个文件,虽然可以利用索引,但还是免不了频繁的移动硬盘的磁头 面试官:也就是说频繁的移动磁头会影响性能对吧 我:是的,现在的开源框架不都喜欢说自己通过顺序读写大大的提升了性能吗,比如 面试官:说的没错,那你认为 我:奇怪缓存怎么占用了1.2G多 面试官: 你有没有想过
品,你细品 思考了几分钟后 我:这么随便就释放了 面试官: 不完全对 我:难道是?想起来《CSAPP》(深入理解计算机系统)里面说过一句话
翻译成人话,就是说Linux会把内存当作是硬盘的高速缓存 面试官:现在知道那道送分题应该怎么回答了吧 我:我… Join算法面试官:再给你个机会,如果让你来实现Join算法你会怎么做? 我:无索引的话,嵌套循环就完事了嗷。有索引的话,则可以利用索引来提升性能. 面试官:说回 我:在扫描过程中,数据库会选择一个表把他要返回以及需要进行和其他表进行比较的数据放进 面试官:有索引的情况下是怎么处理的? 我:这个就比较简单了,直接读取两个表的索引树进行比较就完事了嗷,我这边介绍一下无索引的处理方式 Nested Loop Join 嵌套循环,每次只读取表中的一行数据,也就是说如果outerTable有10万行数据, innerTable有100行数据,需要读取 当然现在没啥数据库引擎使用这种算法(太慢了) Block nested loop
当没有索引可以使用的时候,MySQL InnoDB 就会使用这种算法 考虑以下两个表 当无法使用索引执行join操作的时候,InnoDB会自动使用 总结上学时,数据库老师最喜欢考数据库范式,直到上班才学会一切以性能为准,能冗余就冗余,实在冗余不了的就 到此这篇关于为什么代码规范要求SQL语句不要过多的join的文章就介绍到这了,更多相关SQL语句不要过多join内容请搜索极客世界以前的文章或继续浏览下面的相关文章希望大家以后多多支持极客世界! |
请发表评论