1.Mysql中索引的概念
???????MySQL索引的建立對(duì)于MySQL的高效運(yùn)行是很重要的,索引可以大大提高M(jìn)ySQL的檢索速度辛萍。打個(gè)比方,如果合理的設(shè)計(jì)且使用索引的MySQL是一輛蘭博基尼的話,那么沒(méi)有設(shè)計(jì)和使用索引的MySQL就是一個(gè)人力三輪車魁索。創(chuàng)建索引時(shí)狸吞,你需要確保該索引是應(yīng)用在SQL 查詢語(yǔ)句的條件(一般作為 WHERE 子句的條件)勉耀。 實(shí)際上,索引也是一張表蹋偏,該表保存了主鍵與索引字段便斥,并指向?qū)嶓w表的記錄。
索引一般分為:主鍵索引威始、唯一索引枢纠、普通索引、全文索引字逗、組合索引
???????上面都在說(shuō)使用索引的好處京郑,但過(guò)多的使用索引將會(huì)造成濫用宅广。因此索引也會(huì)有它的缺點(diǎn):雖然索引大大提高了查詢速度,同時(shí)卻會(huì)降低更新表的速度些举,如對(duì)表進(jìn)行INSERT跟狱、UPDATE和DELETE。因?yàn)楦卤頃r(shí)户魏,MySQL不僅要保存數(shù)據(jù)驶臊,還要保存一下索引文件。建立索引會(huì)占用磁盤空間的索引文件叼丑。
2.索引的基本創(chuàng)建关翎,刪除以及數(shù)據(jù)庫(kù)表的修改
單列索引的基本創(chuàng)建格式是:
CREATE (UNQIUE)INDEX +索引名稱+ON+表名(列名(長(zhǎng)度))
例如:create unique index ac on sys_user(account);
修改表結(jié)構(gòu)的方式創(chuàng)建索引:
ALTER TABLE+表名+ADD(UNIQUE) INDEX+索引名稱(列名)
例如:alter table sys_user add unique index pa(password);
或者也可以創(chuàng)建表的時(shí)候指明:
CREATE TABLE sys_user(
id INT NOT NULL primary key,
account VARCHAR(16) NOT NULL,
password VARCHAR(32) NOT NULL,
INDEX ac (account (16))
);
刪除索引的語(yǔ)法:
DROP INDEX 索引名稱 ON 表 或者 alter table 表名 drop index 索引名;
例如:drop index pa on sys_user;& alter table sys_user drop index pa;
顯示索引信息:
格式:SHOW INDEX FROM 表名;
SHOW INDEX FROM sys_user;