【实战篇】执行计划3种看法,2种操作,4个误区


1五一长假


本人绝对不是 996 的崇尚者,该工作的时候,高效工作(尽管高效是自认为的);该浪的时候,疯狂得浪。正所谓学要学得尽兴,玩要玩得开心(虽然可能鲁迅没说过这话)。


虽然摄影艺术不咋的,却是一个十足的驴友。放几张这两年到过的地方,大家可以猜猜看,这都是哪?


640?wx_fmt=png

640?wx_fmt=png

640?wx_fmt=jpeg

640?wx_fmt=jpeg

640?wx_fmt=jpeg


本想放一张自己狂奔的照,看着太扎眼了,放弃!


翻看这些旧相册,每当心情抑郁的时候,就彻底被治愈了。2 年内居然没有任何想出去的冲动。然而岁月不仅是把杀猪刀,也是个神偷,偷走了我所有的记忆,慢慢又忍不住想去浪了。所以今年定了 2 个点,一是香港,继续买买买,顺便走下麦里浩劲这条徒步者的圣径。二是泰国,据说有 600百万人配枪,始终没有胆子去挑战一下。然而周围人都去了,毫发无伤的回来,难道奇迹会发生在我身上?



27 X 24 Support


收!我是来讲正事的。


在旅游的过程中,当然必备 OnCall 设备,手机+电脑+远程卡!每次都是祈祷,千万别来电话,但往往你惦记什么,就来什么。出来混,总是要还的。没有经历过风雪中的 support, 是不完整的。


640?wx_fmt=png

(图为滑雪中被 OnCall 的 Joma)


远方的小 C 苦苦得盯着屏幕,望眼欲穿。三板斧教给她了,但还是要从实战中汲取经验。


但有时候,碰到这么个场景,作为新手,你告诉我该怎么下手?


640?wx_fmt=png


又或者是这样的:


640?wx_fmt=png


虽然你租了昂贵的滑雪板,滑雪鞋,滑雪杖,但一个电话过来,你还得远程辅助。我理解 Joma 内心的复杂感受,不知道多少马经过。但一马归一马,事情还是要解决。


所以想要玩得尽心,平时可得多上心写好文档。老司机要注意,多培养新生代力量,关键时刻顶用,不管你觉得老板对你说的“要培养一个像你一样的高手”有多么扯淡。


3玩法



3 种执行计划的看法:



第一种应该都会了吧:


640?wx_fmt=png


一目了然,最左边是顶点,从右往左依次是数据的流向。




第二种是我们重点要讲解的, xml 格式的执行计划。如下:


640?wx_fmt=png


为什么要重点学习这个格式的执行计划呢?聪明如你肯定想到了,没错!就是为了让风雪之中的 Joma 可以赶紧帮你找到调优的关键所在啊。


什么,你不知道如何调出这个 xml 格式的执行计划?翻翻看,我以前铁定讲过了。当我们调出这个 xml 之后,保存成 .sqlplan 的文件,传送给你们的 DBA 就可以了。别说是我说的!


记住,一定是保存成 .sqlplan 的文件,他才能打开如 GUI (上一张图)显示的那般生动。



第三种是 text 格式的,这种风格最简洁:


640?wx_fmt=png


这种对于老司机来说,最喜欢用了,超级简洁。


当然我知道对于 Oracle 熟悉的朋友来说,这种才是最想要的:


640?wx_fmt=png


有执行步骤,更有成本估算值。



2 种操作:


刚才大家都看到了,其实执行计划分为 2 种模式,一种是预估模式(estimated execution plan), 另一种是(actual execution plan). 本质区别在于预估模式并不需要执行查询,仅仅检查语法,判断数据库对象的可用性,以及由优化器选择一个最优的计划。


我们在星球里着重讨论了优化器的工作流程以及注意部分,这里就不累述了:


640?wx_fmt=png



感兴趣的就来吧。每邀请一位朋友,返你 24.15 元!


希望你是学东西而来。


640?wx_fmt=png


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

dbLenis

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值