久久久久久久视色,久久电影免费精品,中文亚洲欧美乱码在线观看,在线免费播放AV片

<center id="vfaef"><input id="vfaef"><table id="vfaef"></table></input></center>

    <p id="vfaef"><kbd id="vfaef"></kbd></p>

    
    
    <pre id="vfaef"><u id="vfaef"></u></pre>

      <thead id="vfaef"><input id="vfaef"></input></thead>

    1. 站長資訊網(wǎng)
      最全最豐富的資訊網(wǎng)站

      歸納整理MySQL數(shù)據(jù)庫常見面試題

      本篇文章給大家?guī)砹岁P(guān)于mysql的相關(guān)知識,其中主要介紹了關(guān)于數(shù)據(jù)庫廠家面試題的一些總結(jié),下面一起來看一下,希望對大家有幫助。

      歸納整理MySQL數(shù)據(jù)庫常見面試題

      推薦學(xué)習(xí):mysql視頻教程

      1、數(shù)據(jù)庫的常用范式:

      • 第一范式(1NF):指表的列不可再分,數(shù)據(jù)庫中表的每一列都是不可分割的基本數(shù)據(jù)項,同一列中不能有多個值;
      • 第二范式(2NF):在 1NF 的基礎(chǔ)上,還包含兩部分的內(nèi)容:一是表必須有一個主鍵;二是表中非主鍵列必須完全依賴于主鍵,不能只依賴于主鍵的一部分;
      • 第三范式(3NF):在 2NF 的基礎(chǔ)上,消除非主鍵列對主鍵的傳遞依賴,非主鍵列必須直接依賴于主鍵。
      • BC范式(BCNF):在 3NF 的基礎(chǔ)上,消除主屬性對于碼部分的傳遞依賴

      2、SQL語句的執(zhí)行過程:

      2.1、客戶端的數(shù)據(jù)庫驅(qū)動與數(shù)據(jù)庫連接池:

      (1)客戶端與數(shù)據(jù)庫進行通信前,通過數(shù)據(jù)庫驅(qū)動與MySQL建立連接,建立完成之后,就發(fā)送SQL語句

      (2)為了減少頻繁創(chuàng)建和銷毀連接造成系統(tǒng)性能的下降,通過數(shù)據(jù)庫連接池維護一定數(shù)量的連接線程,當(dāng)需要進行連接時,就直接從連接池中獲取,使用完畢之后,再歸還給連接池。常見的數(shù)據(jù)庫連接池有 Druid、C3P0、DBCP

      2.2、MySQL架構(gòu)的Server層的執(zhí)行過程:

      (1)連接器:主要負責(zé)跟客戶端建立連接、獲取權(quán)限、維持和管理連接

      (2)查詢緩存:優(yōu)先在緩存中進行查詢,如果查到了則直接返回,如果緩存中查詢不到,在去數(shù)據(jù)庫中查詢。

      MySQL緩存是默認關(guān)閉的,也就是說不推薦使用緩存,并且在MySQL8.0 版本已經(jīng)將查詢緩存的整塊功能刪掉了。這主要是它的使用場景限制造成的:

      • 先說下緩存中數(shù)據(jù)存儲格式:key(sql語句)- value(數(shù)據(jù)值),所以如果SQL語句(key)只要存在一點不同之處就會直接進行數(shù)據(jù)庫查詢了;
      • 由于表中的數(shù)據(jù)不是一成不變的,大多數(shù)是經(jīng)常變化的,而當(dāng)數(shù)據(jù)庫中的數(shù)據(jù)變化了,那么相應(yīng)的與此表相關(guān)的緩存數(shù)據(jù)就需要移除掉;

      (3)解析器/分析器:分析器的工作主要是對要執(zhí)行的SQL語句進行詞法解析、語法解析,最終得到抽象語法樹,然后再使用預(yù)處理器對抽象語法樹進行語義校驗,判斷抽象語法樹中的表是否存在,如果存在的話,在接著判斷select投影列字段是否在表中存在等。

      (4)優(yōu)化器:主要將SQL經(jīng)過詞法解析、語法解析后得到的語法樹,通過數(shù)據(jù)字典和統(tǒng)計信息的內(nèi)容,再經(jīng)過一系列運算 ,最終得出一個執(zhí)行計劃,包括選擇使用哪個索引

      在分析是否走索引查詢時,是通過進行動態(tài)數(shù)據(jù)采樣統(tǒng)計分析出來;只要是統(tǒng)計分析出來的,那就可能會存在分析錯誤的情況,所以在SQL執(zhí)行不走索引時,也要考慮到這方面的因素

      (5)執(zhí)行器:根據(jù)一系列的執(zhí)行計劃去調(diào)用存儲引擎提供的API接口去調(diào)用操作數(shù)據(jù),完成SQL的執(zhí)行。

      2.3、Innodb存儲引擎的執(zhí)行過程:

      • (1)首先MySQL執(zhí)行器根據(jù) 執(zhí)行計劃 調(diào)用存儲引擎的API查詢數(shù)據(jù)
      • (2)存儲引擎先從緩存池buffer pool中查詢數(shù)據(jù),如果沒有就會去磁盤中查詢,如果查詢到了就將其放到緩存池中
      • (3)在數(shù)據(jù)加載到 Buffer Pool 的同時,會將這條數(shù)據(jù)的原始記錄保存到 undo 日志文件中
      • (4)innodb 會在 Buffer Pool 中執(zhí)行更新操作
      • (5)更新后的數(shù)據(jù)會記錄在 redo log buffer 中
      • (6)提交事務(wù)在提交的同時會做以下三件事
      • (7)(第一件事)將redo log buffer中的數(shù)據(jù)刷入到redo log文件中
      • (8)(第二件事)將本次操作記錄寫入到 bin log文件中
      • (9)(第三件事)將bin log文件名字和更新內(nèi)容在 bin log 中的位置記錄到redo log中,同時在 redo log 最后添加 commit 標記
      • (10)使用一個后臺線程,它會在某個時機將我們Buffer Pool中的更新后的數(shù)據(jù)刷到 MySQL 數(shù)據(jù)庫中,這樣就將內(nèi)存和數(shù)據(jù)庫的數(shù)據(jù)保持統(tǒng)一了

      3、常用的存儲引擎?InnoDB與MyISAM的區(qū)別?

      存儲引擎是對底層物理數(shù)據(jù)執(zhí)行實際操作的組件,為Server服務(wù)層提供各種操作數(shù)據(jù)的API。常用的存儲引擎有InnoDB、MyISAM、Memory。這里我們主要介紹InnoDB 與 MyISAM 的區(qū)別:

      (1)事務(wù):MyISAM不支持事務(wù),InnoDB支持事務(wù)

      (2)鎖級別:MyISAM只支持表級鎖,InnoDB支持行級鎖和表級鎖,默認使用行級鎖,但是行鎖只有通過索引查詢數(shù)據(jù)才會使用,否則將使用表鎖。行級鎖在每次獲取鎖和釋放鎖的操作需要消耗比表鎖

      贊(0)
      分享到: 更多 (0)
      網(wǎng)站地圖   滬ICP備18035694號-2    滬公網(wǎng)安備31011702889846號