MySQL是一個非常流行的關系型數據庫管理系統。它支持多種存儲引擎,每種引擎都有自己的特點和優勢。其中,InnoDB是MySQL的默認存儲引擎。在InnoDB中,索引被設計為B+樹。
CREATE TABLE students ( id INT UNSIGNED AUTO_INCREMENT PRIMARY KEY, name VARCHAR(30) NOT NULL, age INT NOT NULL, score FLOAT NOT NULL ) ENGINE=InnoDB;
在上面的示例中,我們創建了一個名為students的表,其中包含id、name、age和score四個字段。在這個示例中,id是主鍵,也就是說它是唯一的,而且可以自動遞增。主鍵是一種非常特殊的索引,它的作用是保證每一行記錄的唯一性。在InnoDB中,主鍵的實現方式是B+樹。
除了主鍵索引以外,MySQL還支持很多其他類型的索引,比如唯一索引、全文索引、空間索引等。不同類型的索引適用于不同的場景。如果我們需要在某個字段上保證唯一性,那么可以使用唯一索引。如果我們需要對文本內容進行搜索,那么可以使用全文索引。如果我們需要在二維平面上進行坐標搜索,那么可以使用空間索引。在InnoDB中,這些索引的實現方式仍然是B+樹。
ALTER TABLE students ADD INDEX age_index(age);
在上面的示例中,我們在表students的age字段上創建了一個索引。這個索引的類型是普通索引,它不需要滿足唯一性的要求。普通索引和唯一索引的實現方式是完全一樣的,都是B+樹。