电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

MySQL Select語句是如何執行的

瀏覽:12日期:2023-10-09 16:51:48

MySQL Select語句是怎么執行的?

最近在極客時間看丁奇大佬的《MySQL45講》,真心覺得講的不錯,把其中獲得的一些MySQL方向的經驗整理整理分享給大家,有興趣同學可以購買相關課程進行學習。

今天分享的內容是select和update的執行流程。

select的執行過程

話不多說,來個神圖鎮樓(自己畫的)。

MySQL Select語句是如何執行的

首先,我們可以看到,整個select語句包含三個模塊,其中客戶端和MySQL兩個部分,MySQL又包含server端和存儲引擎側,server端包含連接器、查詢緩存、分析器、優化器,執行器等多個部分,存儲引擎側同樣包含innodb、Myisam,memory等多種存儲引擎。

每個模塊的作用如下:

連接器:

連接器的任務是跟客戶端建立連接,查詢權限,維持和管理連接等等。當我們使用命令行登錄時,如果密碼或者賬號錯誤,那么連接器會返回給我們Access Deny的報錯,利用正確的賬號密碼登錄到MySQL之后,連接器會查詢當前賬號的登錄權限,之后的所有操作,都是依賴這個權限進行的。

注意,如果此時我們更改了該賬號的權限,并不會對已經存在的連接產生影響,而只對新加入的連接產生影響。

如果客戶端連接進入MySQL后,一直沒有進行任何操作,那么連接器將會在wait_timeout參數設置的時間后,將該連接斷開。建議在程序中使用長連接,這樣可以減小和客戶端和MySQL建立連接的帶來的性能損耗。

查詢緩存:

當客戶端輸入一個SQL之后,如果命中查詢緩存,那么MySQL將會直接返回結果,而不進行下面的一系列分析操作,如果沒有命中,則開始進入分析器---優化器---執行器這個流程。關于查詢緩存,還有2點需要注意:

a、MySQL8.0中開始棄用查詢緩存,因為查詢緩存的命中率一般較低,弊大于利。

b、在高并發場景中,建議將查詢緩存關閉,關閉時使用query_cache_type=off或者query_cache_size=0。

c、如果非要使用這個功能,可以將參數query_cache_type設置成DEMAND,這樣,就可以使用select sql_cache * from table這種方式強制使用查詢緩存的功能了。

分析器:

如果我們的查詢沒有真正命中查詢緩存,那么就要進入分析器這個環節了,分析器的主要功能是詞法分析和語法分析,其中:

詞法分析指的是根據SQL分析出來select、update、alter、列名、表名、庫名等;

語法分析是指需要分析你寫的SQL是否滿足MySQL的語法。如果不滿足,則會給出you have an error xxx的提示。

優化器:

優化器的作用是選出SQL執行的最佳路徑,例如在多表join的時候,優化器會選擇最高效的方案來執行連接查詢。這里可以給出一個例子,例如我們建立了(a,b)的聯合索引,

select * from table where a=1 and b=1;

select * from table where b=1 and a=1;

這兩條SQL是等價的,因為優化器會將下面的改造成上面的樣子,從而應用聯合索引進行搜索查詢。

執行器:

SQL經過優化器之后,就會進入執行器,執行SQL前,需要校驗表的權限,如果有權限,會根據表的存儲引擎定義,去使用這個存儲引擎提供的接口,最終將數據返回給客戶端,并開始等待新的連接。

這里需要注意一點:執行器調用一次,在引擎內部則掃描了多行,因此存儲引擎掃描行數跟rows_examined并不是完全相同的。

Q && A

Q1:為什么對權限的檢查不在優化器之前做?

A1:有些時候,SQL語句要操作的表不只是SQL字面上那些。比如如果有個觸發器,得在執行器階段(過程中)才能確定。優化器階段前是無能為力的

Q2:MySQL權限到底在哪里驗證?

A2:賬號的登錄權限在連接器模塊驗證;表的操作權限分為兩種情況,如果命中查詢緩存,會在查詢緩存放回結果的時候驗證,在優化器之前,如果沒有命中索引,則權限驗證在執行器模塊驗證。

以上就是MySQL Select語句是如何執行的的詳細內容,更多關于MySQL Select語句的資料請關注好吧啦網其它相關文章!

標簽: MySQL 數據庫
相關文章:
主站蜘蛛池模板: 台湾阳明固态继电器-奥托尼克斯光电传感器-接近开关-温控器-光纤传感器-编码器一级代理商江苏用之宜电气 | 高柔性拖链电缆_卷筒电缆_耐磨耐折聚氨酯电缆-玖泰特种电缆 | 西安微信朋友圈广告投放_微信朋友圈推广_西安度娘网络科技有限公司 | 采暖炉_取暖炉_生物质颗粒锅炉_颗粒壁炉_厂家加盟批发_烟台蓝澳采暖设备有限公司 | 长沙广告公司|长沙广告制作设计|长沙led灯箱招牌制作找望城湖南锦蓝广告装饰工程有限公司 | 超声波破碎仪-均质乳化机(供应杭州,上海,北京,广州,深圳,成都等地)-上海沪析实业有限公司 | 西宁装修_西宁装修公司-西宁业之峰装饰-青海业之峰墅级装饰设计公司【官网】 | 上海质量认证办理中心 | 焊锡丝|焊锡条|无铅锡条|无铅锡丝|无铅焊锡线|低温锡膏-深圳市川崎锡业科技有限公司 | 桐城新闻网—桐城市融媒体中心主办 | 伺服电机_直流伺服_交流伺服_DD马达_拓达官方网站 | 交通信号灯生产厂家_红绿灯厂家_电子警察监控杆_标志杆厂家-沃霖电子科技 | 新能源汽车教学设备厂家报价[汽车教学设备运营18年]-恒信教具 | 冲击式破碎机-冲击式制砂机-移动碎石机厂家_青州市富康机械有限公司 | 工业淬火油烟净化器,北京油烟净化器厂家,热处理油烟净化器-北京众鑫百科 | 小型气象站_便携式自动气象站_校园气象站-竞道气象设备网 | 青岛球场围网,青岛车间隔离网,青岛机器人围栏,青岛水源地围网,青岛围网,青岛隔离栅-青岛晟腾金属制品有限公司 | 硫酸亚铁-聚合硫酸铁-除氟除磷剂-复合碳源-污水处理药剂厂家—长隆科技 | 防爆鼓风机-全风-宏丰鼓风机-上海梁瑾机电设备有限公司 | 家乐事净水器官网-净水器厂家「官方」 | 塑料薄膜_PP薄膜_聚乙烯薄膜-常州市鑫美新材料包装厂 | 热缩管切管机-超声波切带机-织带切带机-无纺布切布机-深圳市宸兴业科技有限公司 | 淘趣英语网 - 在线英语学习,零基础英语学习网站 | 吉祥新世纪铝塑板_生产铝塑板厂家_铝塑板生产厂家_临沂市兴达铝塑装饰材料有限公司 | 贵州水玻璃_-贵阳花溪闽兴水玻璃厂 | 大行程影像测量仪-探针型影像测量仪-增强型影像测量仪|首丰百科 大通天成企业资质代办_承装修试电力设施许可证_增值电信业务经营许可证_无人机运营合格证_广播电视节目制作许可证 | pbootcms网站模板|织梦模板|网站源码|jquery建站特效-html5模板网 | 聚合氯化铝-碱式氯化铝-聚合硫酸铁-聚氯化铝铁生产厂家多少钱一吨-聚丙烯酰胺价格_河南浩博净水材料有限公司 | 环氧乙烷灭菌器_压力蒸汽灭菌器_低温等离子过氧化氢灭菌器 _低温蒸汽甲醛灭菌器_清洗工作站_医用干燥柜_灭菌耗材-环氧乙烷灭菌器_脉动真空压力蒸汽灭菌器_低温等离子灭菌设备_河南省三强医疗器械有限责任公司 | 塑胶跑道_学校塑胶跑道_塑胶球场_运动场材料厂家_中国塑胶跑道十大生产厂家_混合型塑胶跑道_透气型塑胶跑道-广东绿晨体育设施有限公司 | 煤棒机_增碳剂颗粒机_活性炭颗粒机_木炭粉成型机-巩义市老城振华机械厂 | 苹果售后维修点查询,苹果iPhone授权售后维修服务中心 – 修果网 拼装地板,悬浮地板厂家,悬浮式拼装运动地板-石家庄博超地板科技有限公司 | 双杰天平-国产双杰电子天平-美国双杰-常熟双杰仪器 | 新车测评网_网罗汽车评测资讯_汽车评测门户报道 | 玻璃钢板-玻璃钢防腐瓦-玻璃钢材料-广东壹诺 | 电动球阀_不锈钢电动球阀_电动三通球阀_电动调节球阀_上海湖泉阀门有限公司 | LED太阳能中国结|发光红灯笼|灯杆造型灯|节日灯|太阳能灯笼|LED路灯杆装饰造型灯-北京中海轩光电 | 智慧物联网行业一站式解决方案提供商-北京东成基业 | 企典软件一站式企业管理平台,可私有、本地化部署!在线CRM客户关系管理系统|移动办公OA管理系统|HR人事管理系统|人力 | 武汉画册印刷厂家-企业画册印刷-画册设计印刷制作-宣传画册印刷公司 - 武汉泽雅印刷厂 | 沙盘模型公司_沙盘模型制作公司_建筑模型公司_工业机械模型制作厂家 |