国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > PHP > 正文

基于MySQL體系結(jié)構(gòu)的分析

2024-05-04 23:07:52
字體:
供稿:網(wǎng)友

了解MySql必須牢牢記住其體系結(jié)構(gòu)圖,Mysql是由SQL接口,解析器,優(yōu)化器,緩存,存儲引擎組成的

 

基于MySQL體系結(jié)構(gòu)的分析

 

1 Connectors指的是不同語言中與SQL的交互

2 Management Serveices & Utilities: 系統(tǒng)管理和控制工具

3 Connection Pool: 連接池。

管理緩沖用戶連接,線程處理等需要緩存的需求

4 SQL Interface: SQL接口。

接受用戶的SQL命令,并且返回用戶需要查詢的結(jié)果。比如select from就是調(diào)用SQL Interface

5 Parser: 解析器。

SQL命令傳遞到解析器的時候會被解析器驗證和解析。解析器是由Lex和YACC實現(xiàn)的,是一個很長的腳本。

主要功能:

a . 將SQL語句分解成數(shù)據(jù)結(jié)構(gòu),并將這個結(jié)構(gòu)傳遞到后續(xù)步驟,以后SQL語句的傳遞和處理就是基于這個結(jié)構(gòu)的

b. 如果在分解構(gòu)成中遇到錯誤,那么就說明這個sql語句是不合理的

6 Optimizer: 查詢優(yōu)化器。

SQL語句在查詢之前會使用查詢優(yōu)化器對查詢進行優(yōu)化。他使用的是“選取-投影-聯(lián)接”策略進行查詢。

用一個例子就可以理解: select uid,name from user where gender = 1;

這個select 查詢先根據(jù)where 語句進行選取,而不是先將表全部查詢出來以后再進行g(shù)ender過濾

這個select查詢先根據(jù)uid和name進行屬性投影,而不是將屬性全部取出以后再進行過濾

將這兩個查詢條件聯(lián)接起來生成最終查詢結(jié)果

7 Cache和Buffer: 查詢緩存。

如果查詢緩存有命中的查詢結(jié)果,查詢語句就可以直接去查詢緩存中取數(shù)據(jù)。

這個緩存機制是由一系列小緩存組成的。比如表緩存,記錄緩存,key緩存,權(quán)限緩存等

8 Engine :存儲引擎。

存儲引擎是MySql中具體的與文件打交道的子系統(tǒng)。也是Mysql最具有特色的一個地方。

Mysql的存儲引擎是插件式的。它根據(jù)MySql AB公司提供的文件訪問層的一個抽象接口來定制一種文件訪問機制(這種訪問機制就叫存儲引擎)

現(xiàn)在有很多種存儲引擎,各個存儲引擎的優(yōu)勢各不一樣,最常用的MyISAM,InnoDB,BDB

默認下MySql是使用MyISAM引擎,它查詢速度快,有較好的索引優(yōu)化和數(shù)據(jù)壓縮技術(shù)。但是它不支持事務(wù)。

InnoDB支持事務(wù),并且提供行級的鎖定,應(yīng)用也相當(dāng)廣泛。
Mysql也支持自己定制存儲引擎,甚至一個庫中不同的表使用不同的存儲引擎,這些都是允許的。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 英吉沙县| 祁阳县| 彭州市| 定日县| 稷山县| 新津县| 抚宁县| 瓮安县| 建平县| 资中县| 满城县| 林口县| 彭泽县| 涡阳县| 东至县| 西吉县| 墨竹工卡县| 台湾省| 资源县| 凤台县| 襄垣县| 蓬安县| 武功县| 铅山县| 永平县| 昌黎县| 文登市| 靖边县| 富平县| 吴堡县| 宣恩县| 河源市| 咸宁市| 温州市| 通辽市| 怀化市| 宁陵县| 石泉县| 文昌市| 米易县| 华安县|