百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>数据库> mysql索引怎样运用?
分享文章到:

mysql索引怎样运用?

发布时间:08/01 来源:未知 浏览: 关键词:
在新建索引时,需要考虑哪些列会用于SQL查询,然后为这些列新建一个或多个索引。事实上,索引也是一种表,保留着主键或索引字段,以及一个能将每个记载指向现实表的指针。数据库会员是看不到索引的,它们只是用来加快查询的。 mysql索引的目的在于提高查询效率,可以类比字典,要是要查“mysql”这个单词,我们确定需要定位到m字母,然后从下往下寻到y字母,再寻到剩下的sql。要是没有索引,那么你可能需要把所有单词看一遍才干寻到你想要的。

在新建索引时,需要考虑哪些列会用于 SQL 查询,然后为这些列新建一个或多个索引。事实上,索引也是一种表,保留着主键或索引字段,以及一个能将每个记载指向现实表的指针。数据库会员是看不到索引的,它们只是用来加快查询的。数据库搜寻引擎运用索引来迅速定位记载。

mysql有四种索引(主键索引/普通索引/全文索引/独一索引)

1.索引的增加

1.1主键索引的增加

当一张表,把某个列设为主键的时候,则该列就是主键索引

create table a(  
id int primary key auto_increment,  
name varchar(20) not null default ''  
);  
//这里id就是表的主键

要是当新建表时没有指定主键索引,也可以在新建表之后增加:

alter table table_name add primary key (column name);

1.2普通索引

普通索引个别是在建表后再增加的,

create index 索引名 on table_name(column1,column2);
alter table table_name add index 索引名(column1,column2);

1.3全文索引

第一,全文索引主要针对文本文件,比方文章,标题,全文索引只要MyISAM有效(mysql5.6之后InnoDB也支撑了全文索引)

create table c(  
id int primary key auto_increment ,  
title varchar(20),  
content text,  
fulltext(title,content)  
)engine=myisam charset utf8;  
  
insert into c(title,content) values  
    ('MySQL Tutorial','DBMS stands for DataBase ...'),  
    ('How To Use MySQL Well','After you went through a ...'),  
    ('Optimizing MySQL','In this tutorial we will show ...'),  
    ('1001 MySQL Tricks','1. Never run mysqld as root. 2. ...'),  
    ('MySQL vs. YourSQL','In the following database comparison ...'),  
    ('MySQL Security','When configured properly, MySQL ...');

运用全文索引常见的差错:

select * from c where content like "%mysql%";

这里并不会运用全文索引,可以用explain进行查看。准确用途:

select *  from c where match(title,content) against ('MYSQL');

备注:

1. 在mysql中fulltext 索引只针对 myisam生效

2. mysql本人供给的fulltext针对英文生效->sphinx(coreseek)技术处置中文

3. 运用办法是 match(字段名..) against(‘关键字’)

1.4独一索引

create table d(id int primary key auto_increment , name varchar(32) unique)

d表中name就是独一索引,独一索引可以有多个null,不克不及是反复的内容

比拟主键索引,主键字段不克不及为null,也不克不及反复

2. 查询索引

show indexes from table_name;
show keys from table_name;

3.删除索引

alter table table_name drop index 索引名;

以上就是mysql索引怎样运用?的细致内容,更多请关注 百分百源码网 其它相干文章!

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有151人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板