MySQL之索引与事务

一 索引的概念

一种帮助系统查找信息的数据

数据库索引

是一个排序的列表,存储着索引值和这个值所对应的物理地址无须对整个表进行扫描,通过物理地

址就可以找到所需数据是表中一列或者若干列值排序的方法

需要额外的磁盘空间

索引的作用

1 数据库利用各种快速定位技术,能够大大加快查询速率当表很大或查询涉及到多个表时,可以成干上万倍地提高查询速度

2 可以降低数据库的IO成本,并且还可以降低数据库的排序成本

3 通过创建唯一性索引保证数据表数据的唯一性可以加快表与表之间的连接在使用分组和排序时,可大大减少分组和排序时间

索引的副作用

1 索引需要占用额外的磁盘空间(对于MyISAM引擎而言,索引文件和数据文件是分离的,索引文件用于保存数据记录的地址。而nnoDB 引擎的表数据文件本身就是索引文件当表很大或查询涉及到多个表时,可以成千上万倍地提高查询速度)

2 在插入和修改数据时要花费更多的时间,因为索引也要随之变动

创建索引的原则依据

表的主键、外键必须有索引记录数超过300行的表应该有索引经常与其他表进行连接的表,在连接字段上应该建立索引唯一性太差的字段不适合建立索引更新太频繁地字段不适合创建索引

经常出现在where子句中的字段,特别是大表的字段应该建立索引索引应该建在选择性高的字段上索引应该建在小字段上,对于大的文本字段甚至超长字段不要建卖己

二 索引的分类

1 普通索引

最基本的索类型,没有唯一性之类的限制

创建普通索引的方式

创建表的时候指定索引

CREATE TABLE 表名 ( 字段1 数据类型,字段2 数据类型[,...],INDEX 索引名 (列名));

例:create table test(id int(4) not null,name varchar(10) not null,cardid varchar(18) not null,index id_index (id));

show create table test;

直接创建索引

CREATE INDEX 索引名 ON 表名 (列名[(length)]);

修改表时创建索引

ALTER TABLE 表名 ADD INDEX 索引名 (列名);

创建表的时候指定索引

CREATE TABLE 表名 ( 字段1 数据类型,字段2 数据类型[,...],INDEX 索引名 (列名));

2 唯一索引

与普通索引类似,但区别是唯一索引列的每个值都唯一。

唯一索引允许有空值(注意和主键不同)。如果是用组合索引创建,则列值的组合必须唯一。添加唯一键将自动创建唯一索引。

创建唯一索引
直接创建唯一索引

CREATE UNIQUE INDEX 索引名 ON 表名(列名);

创建表的时候指定

CREATE TABLE 表名 (字段1 数据类型,字段2 数据类型[,...],UNIQUE 索引名 (列名));

3 主键索引

是一种特殊的唯一索引,必须指定为"PRIMARY KEY"。

一个表只能有一个主键,不允许有空值。 添加主键将自动创建主键索引。

创建表的时候指定

4 组合索引(单列索引与多列索引)

可以是单列上创建的索引,也可以是在多列上创建的索引。需要满足最左原则,因为select语句的 where条件是依次从左往右执行的,所以在使用select 语句查询时where条件使用的字段顺序必须和组合索引中的排序一致,否则索引将不会生效。

5 全文索引(FULLTEXT)

适合在进行模糊查询的时候使用,可用于在一篇文章中检索文本信息。

在 MySQL5.6 版本以前FULLTEXT 索引仅可用于 MyISAM 引擎,在 5.6 版本之后 innodb 引擎也支持 FULLTEXT 索引。全文索引可以在 CHAR、VARCHAR 或者 TEXT 类型的列上创建。每个表只允许有一个全文索引。

使用全文索引查询

SELECT * FROM 表名 WHERE MATCH(列名) AGAINST('查询内容');

直接创建索引

ALTER TABLE 表名 ADD FULLTEXT 索引名 (列名);

创建表的时候指定索引

CREATE TABLE 表名 (字段1 数据类型[,...],FULLTEXT 索引名 (列名));

#数据类型可以为 CHAR、VARCHAR 或者 TEXT

6 查看索引

show index from 表名;

show index from 表名\G; 竖向显示表索引信息

show keys from 表名;

show keys from 表名\G;

7 删除索引

直接删除索引

DROP INDEX 索引名 ON 表名;

修改表方式删除索引

ALTER TABLE 表名 DROP INDEX 索引名;

删除主键索引

ALTER TABLE 表名 DROP PRIMARY KEY;

三 MySQL事务的概念

它是一个操作序列,这些操作要么都执行,要么都不执行,它是一个不可分割的工作单位

1 事务的ACID特点

原子性:指事务是一个不可再分割的工作单位,事务中的操作要么都发生,要么都不发生。

一致性:指在事务开始之前和事务结束以后,数据库的完整性约束没有被破坏。

隔离性:指在并发环境中,当不同的事务同时操纵相同的数据时,每个事务都有各自的完整数据空间。

持久性:在事务完成以后,该事务所对数据库所作的更改便持久的保存在数据库之中,并不会被回滚。

相关推荐
RisingWave中文开源社区1 小时前
经验分享|用开源产品构建一个高性能实时推荐引擎
数据库·后端·开源
jay丿3 小时前
Django 初始化导入数据详解
数据库·django·sqlite
CodeJourney.3 小时前
用DEEPSEEK做数据看板:高效、实用与创新的融合
数据库·人工智能·python·算法
xuanloyer3 小时前
第二篇《Active Data Guard 实战:打造高可用数据库》(ADG)
运维·数据库·oracle
小王不会写code4 小时前
Unknown collation: ‘utf8mb4_0900_ai_ci‘
数据库·mysql
局外人LZ5 小时前
windows安装Neo4j图数据库
数据库·windows·neo4j
AaronZZH5 小时前
Neo4j 数据库备份
数据库·neo4j
m0_748256145 小时前
Spring 事务失效的 8 种场景!
java·数据库·spring
dowhileprogramming5 小时前
Python Flask 和数据库系统交互
数据库·python·flask
豆浆Whisky5 小时前
【Dev常识】为什么搜索越来越难用?向量数据库揭开了我多年的困惑!
数据库