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. 网页爬虫 - python爬虫翻页问题,请问各位大神我这段代码怎样翻页,还有价格要登陆后才能看到,应该怎么解决2. javascript - jQuery post()方法,里面的请求串可以转换为GBK编码么?可以的话怎样转换?3. javascript - 一排三个框,各个框的间距是15px,距离外面的白框间距也是15px,这个css怎么写?4. html5 - javascript写业务有用到什么编程范式没?5. html5 - vue-cli 装好了 新建项目的好了,找不到项目是怎么回事?6. javascript - vue 数据更新了。但是dom没有更新,,,,,如图7. css3 - 微信前端页面遇到的transition过渡动画的bug8. javascript - vue 手机端项目在进入主页后 在进入子页面,直接按返回出现空白情况9. mysql - C#连接数据库时一直这一句出问题int i = cmd.ExecuteNonQuery();10. javascript - Vue 的依赖追踪属于单向数据绑定还是双向绑定?

网公网安备