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

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

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

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


程序員必須掌握的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工程師面試題


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

免費課程推薦 >>
技術文檔推薦 >>
主站蜘蛛池模板: 久久这里只精品国产99热 | 精品国产一区二区三区19 | 久国产精品久久精品国产四虎 | 美女在线看永久免费网址 | 日韩一级片在线观看 | 美女在线视频观看影院免费天天看 | 久久国产热这里只有精品8 久久国产三级 | 成人欧美日韩高清不卡 | 牛人盗摄一区二区三区视频 | 内衣办公室动漫久久影院 | 最新日本免费一区二区三区中文 | 四虎影视永久在线观看 | 黄色在线免费观看网站 | 黄色片在线免费观看视频 | 成 人 黄 色 大 片 | 久揄揄鲁一二三四区高清在线 | www.黄色一片 | 97久久久久国产精品嫩草影院 | 久久国内精品 | 涩涩视频免费观看 | 日本aⅴ网站 | 色中涩 | 精品久久天干天天天按摩 | 四虎影院在线观看网站 | 首页 动漫 亚洲 欧美 日韩 | 情趣视频网站在线观看 | 偷偷操99 | 亚洲香蕉视频 | 久久久久日韩精品无 | 欧美特级毛片a够爽 | 99999久爱视频在线观看 | 奇米色888| videosex久久麻豆 | 日本不卡高清免费v | 综合图区亚洲白拍在线 | 特级无码a级毛片特黄 | 久久99精品久久久久久国产人妖 | 久久综合亚洲一区二区三区 | 亚洲欧美精品日韩欧美 | 国产欧美一区二区精品久久久 | 国产香蕉75在线播放 |