文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

快速入门MySQL数据库索引的基础知识

2024-04-02 19:55

关注

本文主要给大家介绍快速入门MySQL数据库索引的基础知识,文章内容都是笔者用心摘选和编辑的,具有一定的针对性,对大家的参考意义还是比较大的,下面跟笔者一起了解下快速入门MySQL数据库索引的基础知识吧。

------------------------索引的概念----------------------------

⑴数据库中的索引与书籍中的目录类似
在一本书,无须阅读整本书,利用目录就可以快速查找所需信息
书中的目录是一个词语列表,其中著名了包含个此的页码
⑵数据库索引
在数据库中,索引使数据库程序无须对整个表进行扫描,就可以在其中找到所需数据
数据库中的索引是某一个表中一列或者若干列值的集合,以及物理标识这些值的数据页的逻辑指针清单

优点:加快查询速度、检索速度,可以准确的定位,不需要全篇去找


-------------------------索引的作用------------------------


⑴设置了合适的索引之后,数据库利用各种快速的定位技术,能够大大加快查询速率
⑵特别是当表很大时,或者查询设计到多表时,使用索引可使查询加快千倍
⑶可以降低数据库的IO(输入输出)成本,并且索引还可以降低数据库的排序成本
(读的时候会消耗内存)
⑷通过创建唯一性索引保证数据表数据的唯一性
⑸可以加快表与表之间的连接(可以把相关的字段当做一个索引)
⑹在使用分组的排序时,可大大减少分组和排序时间

 
----------------------索引的分类--------------------------

⑴普通索引
这是最基本的索引类型,而且它没有唯一性之类的限制

⑵唯一性索引
这种索引和前面"普通索引"基本相同,但有一个区别:索引列的所有值都只能出现一次,即必须唯一

⑶主键
这是一种唯一性索引,但它必须指定为"PRIMARY KEY"

⑷全文索引
MySQL3.23.23版开始支持全文索引和全文检索。在MySQL中,全文索引的索引类型为FULLTEXT,全文索引可以再VARCHAR或者TEXT类型的列上创建


------------------创建索引的原则依据-----------------

⑴表的主键、外键必须有索引

⑵数据量超过300行的表应该有索引

⑶经常与其他表进行连接的表,在连接字段上应该建立索引

⑷唯一性太差的字段不适合建立索引(重复性大,大众化,重复很多)

⑸更新太频繁地字段不适合创建索引

⑹经常出现在where子句中的字段,特别是大表的字段,应该建立索引

⑺索引应该建在选择性高的字段上

⑻索引应该建在小字段上,对于大的文本字段甚至超长字段,不要建索引


-----------------创建索引的方法--------------------


根据企业需求选择了合适的索引之后,可使用CREATE INDEX创建索引

CREATE INDEX加上各个索引关键字便可创建各个类型的索引


PS:首先需要进入数据库


⑴创建普通索引

语法结构:create index (索引的名字)on tablename (列的列表)


举例:

mysql> create index salary_index on IT_salary(薪资);                    #创建IT_salary 的索引(默认普通索引),索引名称为salary_index

mysql> show index from IT_salary;                                                 #从IT_index数据表中,查看索引


⑵创建唯一性索引

语法结构:create unique index (索引名字)on tablename (表的名字)

举例:

mysql> create unique index salary_unique on IT_salary(姓名);              #创建IT_salary 的唯一索引,索引名称为salary_unique  

mysql> show index from IT_salary;                                                              #从IT_index数据表中,查看索引


⑶创建主键索引,有两种方式,一种实在创建表的同时创建主键,主键索引自动创建,

命令格式:

create table tablename([…],primary ke(表的名字));                             #创建表的时候,添加了主键,也就是自动创建了

alter table tablename add primary key(列的列表);                           #创建之后忘记添加主键,用此种方法


附加:

更改表结构

添加表 主键,命令格式:alter table <表名> add primary key(id);


1.增加一个列:

alter table info add column age int;

#更改表    info  增加    列    年龄 类型;


2.删除一个列:

  alter table info drop column age;

#更改表      info  删除    列      年龄;


主键索引例子

mysql> alter table IT_salary add primary key(员工ID);


⑷索引查看

show index from tablename;                  

show keys from tablename;


查看索引例子

mysql> show index from IT_salary;       

mysql> show keys from IT_salary;

看完以上关于快速入门MySQL数据库索引的基础知识,很多读者朋友肯定多少有一定的了解,如需获取更多的行业知识信息 ,可以持续关注我们的数据库栏目的。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯