MySQL索引設計原則

一、MySQL常用的索引類型

1.1主鍵索引

primary key

1.2唯一索引

unique

1.3普通索引

index

1.4全文索引

1.5組合索引

二、MySQL常用的數據結構

2.1B-tree

2.2哈希索引

三、索引的設計原則

3.1選擇唯一性索引

被設為唯一性的值可以設置為索引,這樣能快速定位到某條記錄

3.2為經常需要排序、分組和聯合操作的字段建立索引

經常需要order by,group by,distinct,union操作的字段可以設置為索引,因為排序需要很多時間

3.3為常作為查詢條件的字段建立索引

查詢需要消耗很多時間,所以可以將需要經常查詢的字段作為索引

3.4限制索引的數目

不是索引的數目越多越好,建立索引會占用磁盤空間,并且當數據更新時,除了跟新數據庫中,還要跟新索引中的數據,這樣使更新操作變的復雜,需要大量的時間

3.5盡量使用前綴來索引

如果索引字段比較長,盡量使用前綴來索引,比如TEXT和BLOG類型,只需前綴就可定位到對應字段,如果使用全文索引會浪費很多時間

3.6盡量使用數據量少的索引

如果所以的值很長,那么索引的速度也會降低

3.7刪除不再使用或者很少使用的索引

索引的存在會將表的更新操作變的繁瑣,并且占用磁盤空間,應定期檢查不需要的索引,并將其刪除

轉載于:https://www.cnblogs.com/mercuryji/p/mysql_index.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/250448.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/250448.shtml
英文地址,請注明出處:http://en.pswp.cn/news/250448.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Flask-admin 學習及一些筆記

Flask-admin 學習及一些筆記 基本認識:flask-admin是flask的擴張,主要用于對flask應用程序增加管理界面。 some notes: 在 BaseView 的子類中可以定義若干個視圖函數, 使用 Flask-Admin 的 expose 裝飾器來注冊函數為視圖, 這與一般的視圖…

java web 服務器環境搭建之jdk安裝

Java 部署環境搭建 一 安裝centos系統,安裝完成后用root用戶登錄 二 Java 環境安裝 下載jdk安裝包,使用以下命令下載安裝包,也可以在windows環境現在,在上傳到linux機器上curl -O -L http://download.oracle.com/otn-pub/java/jdk/8u191-b12/2787e4a523244c269598db4e85c51e0c/…

koa --- [MVC實現之四]Router、Controller、Service的實現

說明 上一篇: [MVC實現之三]上一篇實現了,Router層、Controller層、Service層的基本原則,并且成功的通過Mar類來傳遞這些層級之間需要的參數.這一篇主要是通過業務層面來具體實現: Router層:監聽頁面的路由,并調用Controller層的路由處理函數Controller層:給Router層提供服務,…

2017-2018-2 20179317 《網絡攻防技術》第七周學習心得體會

教材學習內容總結 課本第七章主要圍繞windows操作系統安全攻防技術進行講述,教材中主要涉及的攻擊內容如下: Windows操作系統的基本結構 運行于處理器特權模式的操作系統內核運行在處理器非特權模式的用戶空間代碼采用宏內核模式來進行構架 Windows操作系…

Jinja的基礎知識

Jinja的基礎知識 介紹&#xff1a;Jinja2 是一個現代的&#xff0c;設計者友好的&#xff0c;仿照 Django 模板的 Python 模板語言。 它速度快&#xff0c;被廣泛使用&#xff0c;并且提供了可選的沙箱模板執行環境保證安全 基本操作 變量&#xff1a;使用{{}}包圍 <a>…

PE文件格式詳解(二)

0x00 前言 上一篇講到了PE文件頭的中IMAGE_FILE_HEADER結構的第二個結構&#xff0c;今天從IMAGE_FILE_HEADER中第三個結構sizeOfOptionalHeader講起。這個字段的結構名也叫做IMAGE_OPTIONAL_HEDAER講起。 0x01 IMAGE_OPTIONAL_HEADER概述 其實這個結構是IMAGE_FILE_HEADER結構…

javascript --- [代碼優化]將復雜的函數分解寫異步請求數據的同步寫法

說明 今天優化項目結構,發現有如下一個函數 const drawMqiPie async (index) > {// 請求的參數let params {lineNo: lineNo,direct: 1,driveway: 1,pageNum: 0,pageSize: 0,computeRange: 3,detectDate: $(#detectYear).val() -01-01}// 請求的urllet url conf.URL s…

20165223《Java程序設計》第八周Java學習總結

教材學習內容總結 第12章-JAVA多線程機制 要點 Java中的線程Thread類與線程的創建線程的常用方法線程同步協調同步的線程線程聯合GUI線程計時器線程教材學習中的問題和解決過程 1. 進程與線程 程序&#xff1a;靜態的代碼&#xff0c;應用執行的藍本進程&#xff1a;程序的一次…

各種平臺的表達芯片跟mRNA-seq數據比較

各種平臺的表達芯片跟mRNA-seq數據比較 RNA-Seq 表達譜 芯片數據分析文章見&#xff1a;http://journals.plos.org/plosone ... ournal.pone.0078644指定的細胞系是&#xff1a;Human CCR6 CD4 memory T cell &#xff0c;測了6個時間點&#xff0c;共12個樣本表達芯片用的…

SQLAlchemy 一些基本操作

SQLAlchemy 一些基本操作 建表&#xff1a;db.create_all() 一次性創建全部的表 插入數據&#xff1a; ? 1、創建變量user User(username “hjj2”,password “1234”) ? 2、使用db.session.add(user)&#xff0c;添加到會話對象中 ? 3、使用db.session.commit()&am…

koa --- [MVC實現之五]Model層的實現

說明 上一篇: MVC實現之四這一篇主要介紹: 項目中用到的Sequelize庫中的一些方法,參考使用Sequelize連接mysql將Model層加入Mar類中 Service層 還是從業務出發,Service層是調用方,調用方式和Controller層調用Service層一樣 class Service {constructor(app) {const { model…

關于字符串 --java

這是在杭電上做一道水題時發現的&#xff0c;挺不錯&#xff0c;寫下了分享一下 http://acm.hdu.edu.cn/showproblem.php?pid2072 這里我用了兩種方法&#xff0c;參考大佬的&#xff0c;一個是list實現類&#xff0c;一個是用set框架 import java.util.*;public class Main {…

三元表達式 列表遞推 生成器表達式

#!/use/bin/python# -*- conding:utf-8 -*-# def my_max(x,y):# if x > y : #>必須緊湊# return x# else:# return y# x 10# y 20# res x if x>y else y# print(res)# name input(>>>:).strip()# res 漂亮小姐姐 if name 汪妍…

node --- 模擬事件的異步

事件 在前端瀏覽器最常見的就是頁面交互事件本質是發布/訂閱設計模式 目標 對象使用add方法訂閱事件。使用emit發布消息 訂閱事件 添加觸發事件的一個唯一字符串,以及對應的處理函數先初始化事件對象 class Event {constructor(){this.events {};} }訂閱在訂閱事件的時候,…

Vue-webpack項目配置詳解

Vue-webpack項目配置詳解 1、首先我們在構建vue項目后&#xff0c;就得先了解vue的項目結構 ├── build --------------------------------- webpack相關配置文件 │ ├── build.js --------------------------webpack打包配置文件 │ ├── check-versions.js ----…

淺談PHP面向對象編程(九)

9.0 設計模式 在編寫程序時經常會遇到一此典型的問題或需要完成某種特定需求&#xff0c;設計模式就是針對這些問題和需求&#xff0c;在大量的實踐中總結和理論化之后優選的代碼結構編程風格&#xff0c;以及解決問題的思考方式。 設計模式就像是經典的棋譜。不同的棋局&#…

javascript --- Object.create的閱讀

說明 今天閱讀koa源碼時,遇到Object.create,感覺對這個概念有點生疏,于是打開了MDN進行重新梳理傳送門 Object.create() 直接套用官網的栗子 const person {isHuman: false,printIntroduction: function () {console.log(My name is ${this.name}. Am I human? ${this.i…

python 12306 車次數據獲取

python 12306 車次數據獲取 ssl._create_default_https_context ssl._create_default_https_context train_data 2018-10-20 headers {User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.100 Safari/537.36,…

Annotation 注解

Annotation分為兩種&#xff0c;第一種為系統內置注解&#xff0c;第二種為自定義注解。系統內置注解&#xff1a;例如Override,Dprecated自定義注解&#xff1a;定義格式為 【public】 interface Annotation名稱{數據類型 變量名稱();}其中數據類型和變量自定義&#xff0c;不…

node --- [node接口閱讀]cluster的使用

目標 在主進程中完成以下事情: 每隔1秒鐘輸出,當前請求的數量創建等同于CPU數量的進程對每個進程施加一個處理函數,用于統計請求的數量 在各個CPU的進程中完成以下事情 監聽8000端口的請求,并返回最簡單的信息發送事件,以觸發主進程中施加的事件處理函數 前置知識 process…