91aaa在线国内观看,亚洲AV午夜福利精品一区二区,久久偷拍人视频,久久播这里有免费视播

<strong id="fvuar"></strong>

  • <sub id="fvuar"><dl id="fvuar"><em id="fvuar"></em></dl></sub>

    1. 千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

      手機站
      千鋒教育

      千鋒學習站 | 隨時隨地免費學

      千鋒教育

      掃一掃進入千鋒手機站

      領(lǐng)取全套視頻
      千鋒教育

      關(guān)注千鋒學習站小程序
      隨時隨地免費學習課程

      當前位置:首頁  >  技術(shù)干貨  > MySQL索引進階

      MySQL索引進階

      來源:千鋒教育
      發(fā)布人:zyh
      時間: 2023-06-12 16:01:00 1686556860

        全文大約【1404】字,不說廢話,只講可以讓你學到技術(shù)、明白原理的純干貨!本文帶有豐富案例及配圖視頻,讓你更好的理解和運用文中的技術(shù)概念,并可以給你帶來具有足夠啟迪的思考......

      MySQL索引進階

        一. 索引

        在上一章節(jié)中小編講解了索引的基本入門。那么在這一節(jié)中我們來探討下索引的深層原理。各位小伙伴準備好了嗎,我們開始嘍!

        1.索引的設(shè)計原則

        索引的設(shè)計可以遵循一些已有的原則,創(chuàng)建索引的時候請盡量考慮符合這些原則,便于提升索引的使用效率,更高效的使用索引。

        2.創(chuàng)建索引的原則:

        ● 對查詢頻次較高,且數(shù)據(jù)量比較大的表建立索引。

        ● 使用唯一索引,區(qū)分度越高,使用索引的效率越高。

        ● 索引字段的選擇,最佳候選列應(yīng)當從where子句的條件中提取,如果where子句中的組合比較多,那么應(yīng)當挑選最常用、過濾效果最好的列的組合。

        ● 使用短索引,索引創(chuàng)建之后也是使用硬盤來存儲的,因此提升索引訪問的I/O效率,也可以提升總體的訪問效率。假如構(gòu)成索引的字段總長度比較短,那么在給定大小的存儲塊內(nèi)可以存儲更多的索引值,相應(yīng)的可以有效的提升MySQL訪問索引的I/O效率。

        ● 索引可以有效的提升查詢數(shù)據(jù)的效率,但索引數(shù)量不是多多益善,索引越多,維護索引的代價自然也就水漲船高。對于插入、更新、刪除等DML操作比較頻繁的表來說,索引過多,會引入相當高的維護代價,降低DML操作的效率,增加相應(yīng)操作的時間消耗。另外索引過多的話,MySQL也會犯選擇困難病,雖然最終仍然會找到一個可用的索引,但無疑提高了選擇的代價。

        3.聯(lián)合索引的使用

        在mysql建立聯(lián)合索引時會遵循最左前綴匹配的原則,即最左優(yōu)先,在檢索數(shù)據(jù)時從聯(lián)合索引的最左邊開始匹配,對列name列、address和列phone列建一個聯(lián)合索引。  

      ALTER TABLE user ADD INDEX index_three(name,address,phone);

        聯(lián)合索引index_three實際建立了(name)、(name,address)、(name,address,phone)三個索引。所以下面的三個SQL語句都可以命中索引。  

      SELECT * FROM user WHERE address = '北京' AND phone = '12345' AND name = '張三';
      SELECT * FROM user WHERE name = '張三' AND address = '北京';
      SELECT * FROM user WHERE name = '張三';

        上面三個查詢語句執(zhí)行時會依照最左前綴匹配原則,檢索時分別會使用下面索引。進行數(shù)據(jù)匹配。

        (name,address,phone)

        (name,address)

        (name)

        索引的字段可以是任意順序的,小編舉個栗子:  

      -- 優(yōu)化器會幫助我們調(diào)整順序,下面的SQL語句都可以命中索引
      SELECT * FROM user WHERE address = '北京' AND phone = '12345' AND name = '張三';

        Mysql的優(yōu)化器會幫助我們調(diào)整where條件中的順序,以匹配我們建立的索引。

        聯(lián)合索引中最左邊的列不包含在條件查詢中,所以根據(jù)上面的原則,下面的SQL語句就不會命中索引。  

      -- 聯(lián)合索引中最左邊的列不包含在條件查詢中,下面的SQL語句就不會命中索引
      SELECT * FROM user WHERE address = '北京' AND phone = '12345';

        二. 結(jié)語

        小編在這里對本文核心要點進行總結(jié):

        熟練記住并理解創(chuàng)建索引的原則和聯(lián)合索引的使用,本章節(jié)主要就是講索引的使用原則和聯(lián)合索引的使用。

      聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
      10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
      請您保持通訊暢通,專屬學習老師24小時內(nèi)將與您1V1溝通
      免費領(lǐng)取
      今日已有369人領(lǐng)取成功
      劉同學 138****2860 剛剛成功領(lǐng)取
      王同學 131****2015 剛剛成功領(lǐng)取
      張同學 133****4652 剛剛成功領(lǐng)取
      李同學 135****8607 剛剛成功領(lǐng)取
      楊同學 132****5667 剛剛成功領(lǐng)取
      岳同學 134****6652 剛剛成功領(lǐng)取
      梁同學 157****2950 剛剛成功領(lǐng)取
      劉同學 189****1015 剛剛成功領(lǐng)取
      張同學 155****4678 剛剛成功領(lǐng)取
      鄒同學 139****2907 剛剛成功領(lǐng)取
      董同學 138****2867 剛剛成功領(lǐng)取
      周同學 136****3602 剛剛成功領(lǐng)取
      相關(guān)推薦HOT
      PUE是什么?

      一、PUE是什么PUE,即功耗比(Power Usage Effectiveness),是數(shù)據(jù)中心的能源效率指標。它是數(shù)據(jù)中心總功耗與設(shè)備功耗的比值,用于評估數(shù)據(jù)中...詳情>>

      2023-10-15 07:13:07
      graph cut和graph cuts有什么區(qū)別?

      1.語境不同graph cut”通常在描述一個操作時使用,比如”perform a graph cut”,它指的是在圖中找到一個切割,將圖劃分為兩個...詳情>>

      2023-10-15 07:02:16
      什么是雙機熱備?

      一、雙機熱備的原理雙機熱備是指在系統(tǒng)中配置兩臺服務(wù)器(主服務(wù)器和備份服務(wù)器),兩者通過高速網(wǎng)絡(luò)連接進行實時數(shù)據(jù)同步和狀態(tài)同步。主服務(wù)器...詳情>>

      2023-10-15 06:37:02
      偏最小二乘支持向量機和支持向量機回歸的區(qū)別是什么?

      1.模型構(gòu)建的理論基礎(chǔ)不同支持向量機回歸(SVR)基于統(tǒng)計學習理論,其主要思想是找到一個超平面,使得大部分數(shù)據(jù)點都在這個超平面的一定范圍內(nèi),...詳情>>

      2023-10-15 06:30:45
      VAE、GAN和transformer有什么區(qū)別?

      1.模型結(jié)構(gòu)不同VAE(變分自編碼器)是一種生成模型,其基于概率圖模型和自編碼器,能夠?qū)W習數(shù)據(jù)的潛在分布。GAN(生成對抗網(wǎng)絡(luò))同樣是一種生成...詳情>>

      2023-10-15 06:10:12