Mysql ------ 索引+ 事务
admin
2023-03-26 02:41:25
0

文章目录

一、索引:

(1)数据库索引:

(2)索引的作用:

(3)索引分类:

(4)创建索引的原则依据:

(5)创建索引的办法:

二、事务:

(1)事务概念:

(2)事务的四大特性:

(3)事务的操作:

三、两表相连查询:

一、索引:

(1)数据库索引:

1、在数据库中,索引使数据程序无须对整个表进行扫描,就可以在其中找到所需数据;
2、数据库中的索引是某个表中一列或者若干列值的集合,以及物理标识这些值的数据页的逻辑指针清单。

(2)索引的作用:

1、数据库能够大大加快查询速率;
2、降低数据库的 IO 成本,并且索引还可以降低数据库的排序成本;
3、通过创建唯一性索引保证数据表数据的唯一性;
4、加快表与表之间的连接;
5、分组和排序的时候,可以大大减少分组和排序时间

(3)索引分类:

1、普通索引 :最基本的索引类型,而且没有唯一性之类的限制;
2、唯一性索引 :与普通索引基本相似,区别在于,索引列的所有值都只能出现一次,即必须唯一;
3、主键 :主键是一种唯一性索引,必须指定为 “ primary key ” ;
4、全文索引 :mysql 从3.23.23版本开始支持全文索引和全文检索,在mysql 中,全文索引的索引类型为 fulltext ,全文索引可以在 varchar 或者 text 类型的列上创建;
5、单列索引与多列索引:索引可以是单列上创建的索引,也可以是在多列上创建的索引。

(4)创建索引的原则依据:

表的主键、外键必须有索引;
数据量超过 300 行的表应该有索引;
经常与其他表进行连接的表,在连接字段上应该建立索引;
唯一性太差的字段不适合建立索引;
更新太频繁的字段不适合创建索引;
经常出现在 where 子句中的字段,特别是大表的字段,应该建立索引;
索引应该建立在选择性高的字段上;
索引应该建立在小字段上,对于大的文本字段甚至超长字段,不要建立索引。

(5)创建索引的办法:

1、创建普通索引:
##创建普通索引
create index 要定义索引名称 on 表名 (列名1,列名2....);
##查看索引
show index from info;
##删除索引
drop index index_age on info;

例如,我们针对下面这张表,给年龄这列创建一个索引:

Mysql ------ 索引+ 事务

Mysql ------ 索引+ 事务

Mysql ------ 索引+ 事务

2、创建唯一性索引:
create unique index <索引的名字> on tablename(列的列表);
##另种方式:
更改表建构方式创建:alter table 表名 add index 索引名称 (列名);
##第三种方式:可以在创建表的时候直接定义

Mysql ------ 索引+ 事务

Mysql ------ 索引+ 事务

Mysql ------ 索引+ 事务

3、创建主键索引:
##在创建新表的时候
creata table tablename ([..],primary key (列的列表));
##在已有的表上设置一个
alter table tablename add primary key (列的列表);
4、创建全文索引:
create fulltext index 索引名称 on 表名(列的列表);
5、创建组合索引:
create index 索引名称 on 表名 (列的列表1,列的列表2.....);
6、查看索引:
show index from tablename;   
show keys from tablename;

二、事务:

(1)事务概念:

简单的说就是把所有的命令作为一个整体一起提交或者撤销,要么一起都执行,要么一起都不执行。

(2)事务的四大特性:

1、原子性:所有元素都必须作为一个整体提交或回滚,任何元素失败,则整个事务都失败;
例如,我们平时下载软件等,如果中途遇到故障等导致安装失败,就会退回到安装软件前的状态。
2、一致性:事务开始之前,数据处于统一、一致的状态;事务完成之后,再次回到一致转态。
3、隔离性:所有并发事务彼此独立,互不相干、影响。
4、持久性:一旦事务被提交,就会被永久地保留在数据库中。

(3)事务的操作:

默认情况下,mysql 的事务都是自动提交的,当 sql 语句提交时事务便自动提交;
手动对事务进行控制的办法(事务处理命令控制或者使用 set命令控制):
1、事务处理命令控制事务:
begin :开始一个事务;
commit :提交一个事务;
rollback :回滚一个事务;

Mysql ------ 索引+ 事务

Mysql ------ 索引+ 事务

接下来,我们开始做回滚操作,想回到哪个节点,就回到那个存档点即可:

Mysql ------ 索引+ 事务

要想回滚到最初状态,直接使用 rollback 命令:

Mysql ------ 索引+ 事务

Mysql ------ 索引+ 事务

Mysql ------ 索引+ 事务

2、使用 set 命令进行控制:

set autocommit=0 :禁止自动提交;

set autocommit=1 :开启自动提交;

Mysql ------ 索引+ 事务

Mysql ------ 索引+ 事务

三、两表相连查询:

例如,下面有两张表,第一张名为 suer;第二种名为 hob,因为这两张表中有部分信息时相关联的,如何操作:

Mysql ------ 索引+ 事务

输入以下命令,将两张表相关联:
1、直接关联:
select * from user inner join hob on user.hobby=hob.id;

Mysql ------ 索引+ 事务

2、还可以按条件关联:
select user.name,hob.name from user inner join hob on user.hobby=hob.id;

Mysql ------ 索引+ 事务

相关内容

热门资讯

【第一资讯】“新老夫子牛牛到底... 网上科普关于“新老夫子牛牛有没有挂”话题很是火热,小编也是针对新老夫子牛牛作*弊开挂的方法以及开挂对...
今日重大通报“来几局到底有挂吗... 家人们!今天小编来为大家解答来几局透视挂怎么安装这个问题咨询软件客服徽9784099的挂在哪里买很多...
原创 生... 来源:网络消息 2025年12月15日,生命科学开放联盟2025年度交流活动在广州举办,南京大学、...
字节三战春晚!豆包能否再造“微... 来源:时代周报-时代在线 图源:视觉中国 近来,豆包动作密集且重磅。 有报道称,火山引擎将成为20...
今日重大消息“728究竟有挂吗... 今日重大消息“728究竟有挂吗?”(太坑了果然有挂)您好,728这个游戏其实有挂的,确实是有挂的,需...
【第一资讯】“齐聚天下怎么开挂... 网上科普关于“齐聚天下有没有挂”话题很是火热,小编也是针对齐聚天下作*弊开挂的方法以及开挂对应的知识...
今日重磅消息“非凡贪玩开挂神器... 网上科普关于“非凡贪玩有没有挂”话题很是火热,小编也是针对非凡贪玩作*弊开挂的方法以及开挂对应的知识...
今日重大通报“决胜麻将是不是有... 网上科普关于“决胜麻将有没有挂”话题很是火热,小编也是针对决胜麻将作*弊开挂的方法以及开挂对应的知识...
最新引进“熊猫麻将到底是不是挂... 家人们!今天小编来为大家解答熊猫麻将透视挂怎么安装这个问题咨询软件客服徽4282891的挂在哪里买很...
我来教教您“闽游麻将究竟有挂吗... 家人们!今天小编来为大家解答闽游麻将透视挂怎么安装这个问题咨询软件客服徽9752949的挂在哪里买很...