MySQL如何加索引?
問題描述
索引可以一起加,還是一個一個加?!
問題解答
回答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` )最常見的就是 3、5這兩種方式了,如:現有一張表:
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;
對它加主鍵索引:
ALTER TABLE `project` ADD PRIMARY KEY ( `p_id` )
對它加組合索引:
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`=? 這是不會用到索引的,應該按下面這樣:select * from `project` where `p_id`=? and `p_name`=? 順序一定要按建索引的來,也可以在查詢語句前加上EXPLAIN查看過程: EXPLAIN select * from `project` where `p_id`=? and `p_name`=?
回答2:就是一些sql語句,你可以一條一條執行,也可以一起執行。
相關文章:
1. html5 - 最近在自學react 求一個react表單提交的例子2. 老師您好!我有一個問題、3. 請問寫好python模塊以后,文檔怎么寫?4. javascript - jq 上傳圖片成功后添加一個新的上傳框時出現問題5. python - django中普通用戶如何利用admin修改自己的信息?6. mysql - 千萬數據 分頁,當偏移量 原來越大時,怎么優化速度7. jquery清除input type為password?8. javascript - uc、qq、搜狗 以上三個手機瀏覽器判斷移動端的js代碼不執行9. 我和老師的代碼對照了幾遍沒發現問題,但是瀏覽器打開就有問題了,求解10. 使用PHP和MySQL的UNIQUE如何像京東注冊那樣保證用戶名唯一?
