MySql的索引操作
索引是一种特殊的数据库结构,可以用来快速查询数据库表中的特定记录。索引是提高数据库性能的重要方式。MySQL中,所有的数据类型都可以被索引。MySQL的索引包括普通索引、唯一性索引、全文索引、单列索引、多列索引和空间索引等。
索引是一种将数据库中单列或者多列的值进行排序的结构。应用索引,可以大幅度提高查询的速度。用户通过索引查询数据,不但可以提高查询速度,也可以降低服务器的负载。用户查询数据时,系统可以不必遍历数据表中的所有记录,而只需查询索引列。一般过程的数据查询是通过遍历全部数据,并寻找数据库中的匹配记录而实现的。与一般形式的查询相比,索引就像一本书的目录。而当用户通过索引查找数据时,就好比用户通过目录查询某章节的某个知识点。这样就帮助用户有效地提高了查找速度。所以,使用索引可以有效地提高数据库系统的整体性能。
应用MySQL数据库时,并非用户在查询数据的时候总需要应用索引来优化查询。凡事都有两面性,使用索引可以提高检索数据的速度,但是,创建和维护索引需要耗费时间,并且该耗费时间与数据量的大小成正比;另外,索引需要占用物理空间,给数据的维护带来很多麻烦。
整体来说,索引可以提高查询的速度,但是会影响用户的插入操作。因为,向有索引的表中插入记录时,数据库系统会按照索引进行排序。所以,用户可以将索引删除后,插入数据,当数据插入操作完成后,用户可以重新创建索引。
不同的存储引擎定义每个表的最大索引数和最大索引长度。所有存储引擎对每个表至少支持16个索引,总索引长度至少为256字节。有些存储引擎支持更多的索引数和更大的索引长度。索引有两种存储类型,包括B型树(BTREE)索引和哈希(HASH)索引。其中B型树为系统默认索引方法。
- 普通索引,即不应用任何限制条件的索引,该索引可以在任何数据类型中创建。字段本身的约束条件可以判断其值是否为空或唯一。创建该类型索引后,用户便可以通过索引进行查询。
- 唯一索引,使用UNIQUE参数可以设置唯一索引。创建该索引时,索引的值必须唯一,通过唯一索引,用户可以快速地定位某条记录,主键是一种特殊的唯一索引。
- 全文索引,使用FULLTEXT参数可以设置索引为全文索引。全文索引只能创建在CHAR、VARCHAR或者TEXT类型的字段上。查询数据量较大的字符串类型的字段时,使用全文索引可以提高查询速度。例如,查询带有文章回复内容的字段。可以应用全文索引方式。需要注意的是,在默认情况下,应用全文索引大小写不敏感。如果索引的列使用二进制排序,则可以执行大小写敏感的全文索引。
- 单列索引即只对应一个字段的索引。其可以包括上述叙述的三种索引方式。应用该索引的条件只需要保证该索引值对应一个字段即可。
- 多列索引是在表的多个字段上创建一个索引。该索引指向创建时对应的多个字段,用户可以通过这几个字段进行查询。要想应用该索引,用户必须使用这些字段中第一个字段。
- 空间索引使用SPATIAL参数可以设置索引为空间索引。空间索引只能建立在空间数据类型上,这样可以提高系统获取空间数据的效率。MySQL中只有MyISAM存储引擎支持空间检索,而且索引的字段不能为空值。
创建索引
创建表时创建
create table [if not exists] 数据表名
(
`id` int(11) unsigned NOT NULL AUTO_INCREMENT,
`hotel_id` int(11) unsigned NOT NULL COMMENT '酒店ID hotel_base的id',
`created_at` datetime NOT NULL DEFAULT now() COMMENT '创建时间',
`updated_at` datetime NOT NULL DEFAULT now() COMMENT '更新时间',
[UNIQUE|FULLTEXT|SPATIAL] INDEX|KEY[别名](属性名1 [(长度)] [ASC|DESC])
PRIMARY KEY (`id`),
KEY `index_hotel_id` (`hotel_id`)
) COMMENT='酒店服务承诺信息' ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE utf8_unicode_ci;
参数含义如下:
UNIQUE:可选参数,表明索引为唯一性索引。
FULLTEXT:可选参数,表明索引为全文搜索。
SPATIAL:可选参数,表明索引为空间索引。
INDEX和KEY参数用于指定字段索引,用户在选择时,只需要选择其中的一种即可。另外别名为可选参数,其作用是给创建的索引命名新名称。
属性名1:指索引对应的字段名称,该字段必须被预先定义。
长度:可选参数,指索引的长度,必须是字符串类型才可以使用。
ASC/DESC:可选参数,ASC表示升序排列,DESC表示降序排列。
create table address (
id int (11) auto_increment primary key not null,
name varchar (50),
address varchar (200),UNIQUE INDEX address (id ASC));
create table telephone(
id int (11) primary key auto_increment not null,
name varchar (50) not null,
tel varchar (50) not null,
index tel_num (tel (20)));
数据表中的字段长度为50,而创建的索引的字段长度为20,这样做的目的是提高查询效率、优化查询速度。
create table information(
id int (11) auto_increment primary key not null,
name varchar (50) not null,
sex varchar (5) not null,
birthday varchar (50) not null,
INDEX info (name, sex));
在多列索引中,只有查询条件中使用了这些字段中的第一个字段(即上面示例中的name字段)时,索引才会被使用。
在已建立的数据表中创建索引
CREATE [UNIQUE|FULLTEXT|SPATIAL] INDEX index_name ON table_name (属性[(length)] [ASC|DESC]);
命令的参数说明如下:
index_name为索引名称,该参数作用是给用户创建的索引赋予新的名称。
table_name为表名,即指定创建索引的表名称。
length为可选参数,用于指定索引长度。
ASC和DESC参数,指定数据表的排序顺序。
与在建立数据表时创建索引相同,在已建立的数据表中创建索引同样包含6种索引方式。
普通索引 CREATE INDEX stu_info ON studentinfo (sid);
唯一索引 CREATE UNIQUE INDEX index1_id ON index1 (cid);
全文索引 CREATE FULLTEXT INDEX index2_info ON index2 (info);
单列索引 CREATE INDEX index3_addr ON index3 (address (4));
多列索引 CREATE INDEX index4_na ON index4 (name, address);
空间索引 CREATE SPATIAL INDEX 索引名 ON 数据表名称 (字段名称);
修改索引
修改已经存在的表上的索引可以通过ALTERTABLE语句为数据表添加索引,其基本结构如下:
ALTER TABLE table_name ADD [UNIQUE|FULLTEXT|SPATIAL] INDEX index_name (属性名[(length)][ASC|DESC]);
alter table studentinfo ADD INDEX timer (time (20)):
删除索引
在MySQL中,创建索引后,如果用户不再需要该索引,则可以删除指定表的索引。因为这些已经被建立且不常使用的索引,一方面可能会占用系统资源,另一方面也可能导致更新速度下降,这极大地影响了数据表的性能。所以,在用户不需要该表的索引时,可以手动删除指定索引。删除索引可以通过DROP语句来实现
DROP INDEX index_name ON table_name;
其中,参数index_name是用户需要删除的索引名称,参数table_name指定数据表名称。
MySql的索引操作的更多相关文章
- mysql语句 索引操作
创建索引:(help create index;) CREATE INDEX indexName ON tableName(Coll,Coll....); ALTER TABLE tableName ...
- Mysql之表的操作与索引操作
表的操作: 1.表的创建: create table if not exists table_name(字段定义); 例子: create table if not exists user(id in ...
- 着重基础之—MySql 不能遗忘的索引操作
着重基础之—MySql 不能遗忘的索引操作 关于MySql索引的基础知识我就不在这里写了,我不太想当信息的搬运工. 技巧分享:Workbench 作为一款专为MySQL设计的ER/数据库建模工具.除了 ...
- MySQL数据库4Python操作mysql、索引、慢查询日志
目录 一.Python 操作 mysql 1.1python 操作 mysql 1.2查询数据 1.3增加(添加.更新)数据 1.4修改数据 1.5删除数据 1.6SQL注入问题 1.6.1问题的引入 ...
- DF学Mysql(三)——索引操作
概要: 数据库对象索引其实与书的目录非常相似,主要是为了提高从表中检索数据的速度. 由于数据存储在数据库表中,所以索引是创建在数据库表对象上的,由表中的一个字段或多个字段生成的键组成,这些键存储在数据 ...
- 【夯实Mysql基础】MySQL性能优化的21个最佳实践 和 mysql使用索引
本文地址 分享提纲: 1.为查询缓存优化你的查询 2. EXPLAIN 你的 SELECT 查询 3. 当只要一行数据时使用 LIMIT 1 4. 为搜索字段建索引 5. 在Join表的时候使用相当类 ...
- 如何正确建立MYSQL数据库索引
索引是快速搜索的关键.MySQL索引的建立对于MySQL的高效运行是很重要的.下面介绍几种常见的MySQL索引类型. 在数据库表中,对字段建立索引可以大大提高查询速度.假如我们创建了一个 mytabl ...
- mysql高性能索引策略
转载说明:http://www.nyankosama.com/2014/12/19/high-performance-index/ 1. 引言 随着互联网时代地到来,各种各样的基于互联网的应用和服务进 ...
- mysql使用索引优化查询效率
索引的概念 索引是一种特殊的文件(InnoDB数据表上的索引是表空间的一个组成部分),它们包含着对数据表里所有记录的引用指针.更通俗的说,数据库索引好比是一本书前面的目录,能加快数据库的查询速度.在没 ...
随机推荐
- Transaction And Lock--存储过程中使用事务的模板
某公司内部使用的模板 create procedure [usp_my_procedure_name] as begin set nocount on; declare @trancount int; ...
- AgentJob--修改操作系统时间对Job的影响
场景:有一个数据库作业每10分钟运行一次,在系统管理员修改操作系统时间后,作业长时间未运行. 分析:作业最后一次运行时间是 10:20,按照作业的计划,下一次的运行时间为 10:30,而系统管理员修改 ...
- IoC概要
控制反转基本上说的是功能调用者与功能实现者之间应该如何交互,即二者之间没有直接的强耦合(调用者new一个被调用者),而是都依赖同一个抽象,这个抽象规定了二者交互的接口.反转的意思是实现了依赖倒置,在程 ...
- controller 状态码
工具使用lombok表示.如没有使用lombok 请 删除@Getter @Setter 并给get set方法 调用方法: 类型使用 Status ---> public ...
- Maven的安装环境变量配置
针对新手刚接触maven,并且不知道如何去搭建和使用maven,那么我来写一篇浅显易懂的初级篇教程吧. 不同的是,别人会先将概念再安装,我来帮大家先搭建好以后再去看概念,不然概念会变的很模糊. 安装 ...
- 导出包含图片的excel、word、pdf 笔记
/** * 导出word * @throws Exception */ @Override public byte[] WordExport( List<VbLibGlobalAnalyList ...
- Ubuntu16.04中把默认JAVA设置为Oracle的JDK!
系统当中已经存在了OpenJDK,默认的JDK是它,并不是Oracle的JDK,执行下面操作就可以把Oracle的JDK设置为默认的了! 首先假设我们已经把Oracle的JDK安装和配置好了,但是就是 ...
- leecode刷题(11)-- 反转字符串
leecode刷题(11)-- 反转字符串 反转字符串 描述: 编写一个函数,其作用是将输入的字符串反转过来. 示例 1: 输入: "hello" 输出: "olleh& ...
- ArchLinux 下安装 SecureCRT
相关说明: 上篇发了个Linux(Ubuntu) 下 SecureCRT 7 30天循环破解在启动的时候会多输入一次确认窗口, 后来maz-1网友留言说可以用Windows破解后程序替换Linux下的 ...
- 「案例」重新设计 Adobe 的文件类型图标
Adobe 的品牌设计团队负责为公司旗下桌面端.移动端和 web 端的产品进行品牌设计.品牌元素的形式很多,可以是两个字母的产品 logo,应用启动界面,产品里的图标等等. 一个很常见却常被忽视的品牌 ...