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

文章目录

1、索引:

(1)数据库索引:

(2)索引的做用:

(3)索引分类:

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

(5)建立索引的办法:

2、事务:

(1)事务概念:

(2)事务的四大特性:

(3)事务的操做:

3、两表相连查询:

1、索引:

(1)数据库索引:

一、在数据库中,索引使数据程序无须对整个表进行扫描,就能够在其中找到所需数据;

二、数据库中的索引是某个表中一列或者若干列值的集合,以及物理标识这些值的数据页的逻辑指针清单。

(2)索引的做用:

一、数据库可以大大加快查询速率;

二、下降数据库的 IO 成本,而且索引还能够下降数据库的排序成本;

三、经过建立惟一性索引保证数据表数据的惟一性;

四、加快表与表之间的链接;

五、分组和排序的时候,能够大大减小分组和排序时间

(3)索引分类:

一、普通索引 :最基本的索引类型,并且没有惟一性之类的限制;

二、惟一性索引 :与普通索引基本类似,区别在于,索引列的全部值都只能出现一次,即必须惟一;

三、主键 :主键是一种惟一性索引,必须指定为 “ primary key ” ;

四、全文索引 :mysql 从3.23.23版本开始支持全文索引和全文检索,在mysql 中,全文索引的索引类型为 fulltext ,全文索引能够在 varchar 或者 text 类型的列上建立;

五、单列索引与多列索引:索引能够是单列上建立的索引,也能够是在多列上建立的索引。

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

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

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

常常与其余表进行链接的表,在链接字段上应该创建索引;

惟一性太差的字段不适合创建索引;

更新太频繁的字段不适合建立索引;

常常出如今 where 子句中的字段,特别是大表的字段,应该创建索引;

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

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

(5)建立索引的办法:

一、建立普通索引:

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

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

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

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

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

二、建立惟一性索引:

create unique index <索引的名字> on tablename(列的列表);
##另种方式:
更改表建构方式建立:alter table 表名 add index 索引名称 (列名);
##第三种方式:能够在建立表的时候直接定义

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

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

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

三、建立主键索引:

##在建立新表的时候
creata table tablename ([..],primary key (列的列表));
##在已有的表上设置一个
alter table tablename add primary key (列的列表);

四、建立全文索引:

create fulltext index 索引名称 on 表名(列的列表);

五、建立组合索引:

create index 索引名称 on 表名 (列的列表1,列的列表2.....);

六、查看索引:

show index from tablename;   
show keys from tablename;

2、事务:

(1)事务概念:

简单的说就是把全部的命令做为一个总体一块儿提交或者撤销,要么一块儿都执行,要么一块儿都不执行。

(2)事务的四大特性:

一、原子性:全部元素都必须做为一个总体提交或回滚,任何元素失败,则整个事务都失败;

例如,咱们平时下载软件等,若是中途遇到故障等致使安装失败,就会退回到安装软件前的状态。

二、一致性:事务开始以前,数据处于统1、一致的状态;事务完成以后,再次回到一致转态。

三、隔离性:全部并发事务彼此独立,互不相干、影响。

四、持久性:一旦事务被提交,就会被永久地保留在数据库中。

(3)事务的操做:

默认状况下,mysql 的事务都是自动提交的,当 sql 语句提交时事务便自动提交;

手动对事务进行控制的办法(事务处理命令控制或者使用 set命令控制):

一、事务处理命令控制事务:

begin :开始一个事务;

commit :提交一个事务;

rollback :回滚一个事务;

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

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

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

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

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

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

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

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

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

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

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

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

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

3、两表相连查询:

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

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

输入如下命令,将两张表相关联:

一、直接关联:

select * from user inner join hob on user.hobby=hob.id;

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

二、还能够按条件关联:

select user.name,hob.name from user inner join hob on user.hobby=hob.id;

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

相关文章
相关标签/搜索