MySQL如何加索引?
問(wèn)題描述
索引可以一起加,還是一個(gè)一個(gè)加?!
問(wèn)題解答
回答1:1.添加PRIMARY KEY(主鍵索引) mysql>ALTER TABLE `table_name` ADD PRIMARY KEY ( `column` ) 2.添加UNIQUE(唯一索引) mysql>ALTER TABLE `table_name` ADD UNIQUE ( `column` ) 3.添加INDEX(普通索引) mysql>ALTER TABLE `table_name` ADD INDEX index_name ( `column` ) 4.添加FULLTEXT(全文索引) mysql>ALTER TABLE `table_name` ADD FULLTEXT ( `column`) 5.添加多列索引 mysql>ALTER TABLE `table_name` ADD INDEX index_name ( `column1`, `column2`, `column3` )最常見(jiàn)的就是 3、5這兩種方式了,如:現(xiàn)有一張表:
DROP TABLE IF EXISTS `project`;CREATE TABLE `project` ( `p_id` varchar(32) NOT NULL, `p_name` varchar(64) DEFAULT NULL, `p_intr` text, `p_save` varchar(512) DEFAULT NULL, `p_ctime` datetime DEFAULT NULL, PRIMARY KEY (`p_id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8;
對(duì)它加主鍵索引:
ALTER TABLE `project` ADD PRIMARY KEY ( `p_id` )
對(duì)它加組合索引:
ALTER TABLE `project` ADD INDEX select_by_id_name KEY ( `p_id`, `p_name` )
這里需要注意索引順序( `p_id`, `p_name` )如果你這么查詢:select * from `project` where `p_name`=? and `p_id`=? 這是不會(huì)用到索引的,應(yīng)該按下面這樣:select * from `project` where `p_id`=? and `p_name`=? 順序一定要按建索引的來(lái),也可以在查詢語(yǔ)句前加上EXPLAIN查看過(guò)程: EXPLAIN select * from `project` where `p_id`=? and `p_name`=?
回答2:就是一些sql語(yǔ)句,你可以一條一條執(zhí)行,也可以一起執(zhí)行。
相關(guān)文章:
1. javascript - 關(guān)于apply()與call()的問(wèn)題2. java - 在用戶不登錄的情況下,用戶如何添加保存到購(gòu)物車?3. javascript - webpack 分割加載代碼后,react 界面不更新4. python 利用subprocess庫(kù)調(diào)用mplayer時(shí)發(fā)生錯(cuò)誤5. datetime - Python如何獲取當(dāng)前時(shí)間6. python文檔怎么查看?7. javascript - nginx反向代理靜態(tài)資源403錯(cuò)誤?8. html - eclipse 標(biāo)簽錯(cuò)誤9. 安全性測(cè)試 - nodejs中如何防m(xù)ySQL注入10. java - spring boot 如何打包成asp.net core 那種獨(dú)立應(yīng)用?
