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

專注Java教育14年 全國咨詢/投訴熱線:400-8080-105
動力節點LOGO圖
始于2009,口口相傳的Java黃埔軍校
首頁 學習攻略 Java學習 Java面試題數據庫部分合集

Java面試題數據庫部分合集

更新時間:2019-12-11 10:23:15 來源:動力節點 瀏覽2349次

 

  為什么用自增列作為主鍵

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

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

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

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

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

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

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

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

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

Java面試題數據庫部分合集.jpg

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

  數據索引的存儲是有序的

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

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

  哈希索引的優勢:

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

  哈希索引不適用的場景:

  不支持范圍查詢

  不支持索引完成排序

  不支持聯合索引的最左前綴匹配規則

  通常,B+樹索引結構適用于絕大多數場景,像下面這種場景用哈希索引才更有優勢:

  在HEAP表中,如果存儲的數據重復度很低(也就是說基數很大),對該列數據以等值查詢為主,沒有范圍查詢、沒有排序的時候,特別適合采用哈希索引,例如這種SQL:

  # 僅等值查詢

  select id, name from table where name='李明';

  而常用的 InnoDB 引擎中默認使用的是B+樹索引,它會實時監控表上索引的使用情況。

  如果認為建立哈希索引可以提高查詢效率,則自動在內存中的“自適應哈希索引緩沖區”建立哈希索引(在InnoDB中默認開啟自適應哈希索引)。

  通過觀察搜索模式,MySQL會利用index key的前綴建立哈希索引,如果一個表幾乎大部分都在緩沖池中,那么建立一個哈希索引能夠加快等值查詢。

  注意:在某些工作負載下,通過哈希索引查找帶來的性能提升遠大于額外的監控索引搜索情況和保持這個哈希表結構所帶來的開銷。

  但某些時候,在負載高的情況下,自適應哈希索引中添加的read/write鎖也會帶來競爭,比如高并發的join操作。like操作和%的通配符操作也不適用于自適應哈希索引,可能要關閉自適應哈希索引。

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

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

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

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

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

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

  MySQL聯合索引

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

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

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

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

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

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

Java面試題數據庫部分合集.jpg

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

 

相關推薦

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

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

Java高級開發工程師面試題

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

哪有資深java工程師面試題

 

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

免費課程推薦 >>
技術文檔推薦 >>
主站蜘蛛池模板: 亚洲欧美另类久久久精品能播放的 | 欧日韩一区二区三区 | 久久久久久毛片免费播放 | 中文字幕国产精品 | 四虎成人国产精品视频 | 四虎在线永久视频观看 | 香蕉爱爱视频 | 精品综合久久久久久88小说 | 国产 麻豆 欧美亚洲综合久久 | 99爱视频| 欧美精品一区二区三区视频 | 色综合久久88色综合天天小说 | 四虎影院入口 | 国产精品久久在线 | 99香蕉国产精品偷在线观看 | 蕾丝视频永久在线入口香蕉 | 亚洲图区欧美 | 四虎在线永久 | 久久久久久久久久综合情日本 | 亚洲精品一区二区久久这里 | 天天拍天天干天天操 | 国产99小视频 | 孕妇孕妇aaaaa级毛片视频 | www.激情五月.com| 欧美在线观看第一页 | 久久久亚洲欧洲国产 | 牛人盗摄一区二区三区视频 | ww亚洲ww亚在线观看 | 97最新网址 | 久久精品国产74国产 | 日本精品一区二区三区在线 | 精品日韩二区三区精品视频 | 国产成人精品免费 | 天天爱添天天爱添天天爱添 | 一区免费在线观看 | 国产精品怡红院永久免费 | 夜夜操网站 | 夜精品a一区二区三区 | 久久综合久久自在自线精品自 | 久久亚洲国产伦理 | 日本一级在线播放线观看免 |