大战熟女丰满人妻av-荡女精品导航-岛国aaaa级午夜福利片-岛国av动作片在线观看-岛国av无码免费无禁网站-岛国大片激情做爰视频

專注Java教育14年 全國咨詢/投訴熱線:400-8080-105
動力節點LOGO圖
始于2009,口口相傳的Java黃埔軍校
首頁 學習攻略 Java學習 程序員必須掌握的Java數據庫面試題及答案

程序員必須掌握的Java數據庫面試題及答案

更新時間:2020-02-13 10:46:56 來源:動力節點 瀏覽2643次


程序員必須掌握的Java數據庫面試題及答案


  為什么用自增列作為主鍵


  1、如果我們定義了主鍵(PRIMARYKEY),那么InnoDB會選擇主鍵作為聚集索引。


  如果沒有顯式定義主鍵,則InnoDB會選擇第一個不包含有NULL值的唯一索引作為主鍵索引。


  如果也沒有這樣的唯一索引,則InnoDB會選擇內置6字節長的ROWID作為隱含的聚集索引(ROWID隨著行記錄的寫入而主鍵遞增,這個ROWID不像ORACLE的ROWID那樣可引用,是隱含的)。


  2、數據記錄本身被存于主索引(一顆B+Tree)的葉子節點上,這就要求同一個葉子節點內(大小為一個內存頁或磁盤頁)的各條數據記錄按主鍵順序存放


  因此每當有一條新的記錄插入時,MySQL會根據其主鍵將其插入適當的節點和位置,如果頁面達到裝載因子(InnoDB默認為15/16),則開辟一個新的頁(節點)


  3、如果表使用自增主鍵,那么每次插入新的記錄,記錄就會順序添加到當前索引節點的后續位置,當一頁寫滿,就會自動開辟一個新的頁


  4、如果使用非自增主鍵(如果身份證號或學號等),由于每次插入主鍵的值近似于隨機,因此每次新紀錄都要被插到現有索引頁得中間某個位置


  此時MySQL不得不為了將新記錄插到合適位置而移動數據,甚至目標頁面可能已經被回寫到磁盤上而從緩存中清掉,此時又要從磁盤上讀回來,這增加了很多開銷


  同時頻繁的移動、分頁操作造成了大量的碎片,得到了不夠緊湊的索引結構,后續不得不通過OPTIMIZETABLE來重建表并優化填充頁面。


  為什么使用數據索引能提高效率


  數據索引的存儲是有序的


  在有序的情況下,通過索引查詢一個數據是無需遍歷索引記錄的


  極端情況下,數據索引的查詢效率為二分法查詢效率,趨近于log2(N)


  B+樹索引和哈希索引的區別


  B+樹是一個平衡的多叉樹,從根節點到每個葉子節點的高度差值不超過1,而且同層級的節點間有指針相互鏈接,是有序的,如下圖:


程序員必須掌握的Java數據庫面試題及答案

  哈希索引就是采用一定的哈希算法,把鍵值換算成新的哈希值,檢索時不需要類似B+樹那樣從根節點到葉子節點逐級查找,只需一次哈希算法即可,是無序的。


  哈希索引的優勢:


  等值查詢,哈希索引具有絕對優勢(前提是:沒有大量重復鍵值,如果大量重復鍵值時,哈希索引的效率很低,因為存在所謂的哈希碰撞問題。)


  為什么說B+比B樹更適合實際應用中操作系統的文件索引和數據庫索引?


  1、B+的磁盤讀寫代價更低。


  B+的內部結點并沒有指向關鍵字具體信息的指針,因此其內部結點相對B樹更小。


  如果把所有同一內部結點的關鍵字存放在同一盤塊中,那么盤塊所能容納的關鍵字數量也越多。一次性讀入內存中的需要查找的關鍵字也就越多。相對來說IO讀寫次數也就降低了。


  2、B+-tree的查詢效率更加穩定。


  由于非終結點并不是最終指向文件內容的結點,而只是葉子結點中關鍵字的索引。所以任何關鍵字的查找必須走一條從根結點到葉子結點的路。所有關鍵字查詢的路徑長度相同,導致每一個數據的查詢效率相當。


  MySQL聯合索引


  1、聯合索引是兩個或更多個列上的索引。


  對于聯合索引:Mysql從左到右的使用索引中的字段,一個查詢可以只使用索引中的一部份,但只能是最左側部分。


  例如索引是keyindex(a,b,c).可以支持a、a,b、a,b,c3種組合進行查找,但不支持b,c進行查找.當最左側字段是常量引用時,索引就十分有效。


  2、利用索引中的附加列,您可以縮小搜索的范圍,但使用一個具有兩列的索引不同于使用兩個單獨的索引。


  復合索引的結構與電話簿類似,人名由姓和名構成,電話簿首先按姓氏對進行排序,然后按名字對有相同姓氏的人進行排序。


  如果您知道姓,電話簿將非常有用;如果您知道姓和名,電話簿則更為有用,但如果您只知道名不知道姓,電話簿將沒有用處。


程序員必須掌握的Java數據庫面試題及答案


      以上就是動力節點Java培訓機構小編介紹的“程序員必須掌握的Java數據庫面試題及答案”的內容,希望對大家有幫助,如有疑問,請在線咨詢,有專業老師隨時為你服務。


相關推薦


最新最全java面試題及答案(初級到高級)


史上最全的中高級JAVA工程師面試題及答案匯總


Java高級開發工程師面試題


2019史上最全java面試題題庫大全800題


哪有資深java工程師面試題


提交申請后,顧問老師會電話與您溝通安排學習

免費課程推薦 >>
技術文檔推薦 >>
主站蜘蛛池模板: 一级黄色免费网站 | 亚洲美女性视频 | 黄色毛片视频免费 | 亚洲欧美日韩不卡一区二区三区 | 夜间福利视频 | 男人免费网站 | 最新狠狠色狠狠色综合 | 久久伊| 一级呦女专区毛片 | 久久久久久综合七次郎 | 国产成人欧美一区二区三区的 | 成人国产精品视频频 | 一区二区三区网站在线免费线观看 | 一级一级 a爱片免费视频 | oldwoman中国老女人tv | 欧美日本激情 | 亚洲精品123区在线观看 | 夜夜操夜夜操 | 亚洲第一se情网站 | 欧美一区2区三区3区公司 | 四虎.com | 伊人久久色 | 久久国产精品久久久久久 | 波多野结衣三区 | 四虎国产精品免费久久麻豆 | 免费一级在线 | 国产成+人+综合+亚洲不卡 | 午夜影院一级片 | 欧美一区色 | 擼擼色在线看观看免费 | 中文精品久久久久国产网站 | 神马影院我不卡影院 | 美女一级大黄录像一片 | www国产永久免费视频看看 | 九九热视频精品 | 神马不卡伦影视 | 香蕉成人啪国产精品视频综合网 | 色色色在线 | 88精品视频| 久久美女精品国产精品亚洲 | 福利在线视频观看 |