【面试】MySQL的事务和索引

来源:互联网 发布:网易上海房产成交数据 编辑:程序博客网 时间:2024/05/29 08:52

MySQL事务
MySQL事务主要用于处理操作量大,复杂度高的数据。
比如说,在人员管理系统中,你删除一个人员,你既需要删除人员的基本资料,也要删除和该人员相关的信息,如信箱,文章等等,这些数据库操作语句就构成一个事务。
(1)在MySQL中只有使用了Innodb数据库引擎的数据库或表才支持事务。
(2)事务处理可以用来维护数据库的完整性,保证成批的sql语句要么全部执行,要么全部不执行。
(3)事务用来管理insert,update,delete语句。
一般来说,事务必须满足4个条件(ACID):Atomicity(原子性)、Consisttency(稳定性)、Isolation(隔离性)、Durability(可靠性)。
(1)事务的原子性:一组事务,要么成功,要么撤回。
(2)事务的稳定性:有非法数据(外键约束之类的),事务撤回。
(3)事务的隔离性:事务独立运行。一个事务处理后的结果,影响了其他事务,要么其他事务会撤回。事务的100%的隔离,需要牺牲速度。
(4)事务的可靠性:软、硬件崩溃后,InnoDB数据库驱动会利用日志文件重构修改,可靠性和高速度不可兼得,innodb_flush_log_at_trx_commit选项,决定什么时候把事务保存到日志里。

在MySQL控制台使用事务来操作:
(1)开始一个事务

start transaction

(2)做保存点
savepoint保存点名称
(3)操作
(4)可以回滚,可以提交,没有问题就提交,有问题就回滚。

MySQL索引:
MySQL索引的建立对于MySQL的高效运行是很重要的,索引可以大大提高MySQL的检索速度。
打个比方,如果合理的设计且使用索引的MySQL是一辆兰博基尼的话,那么没有设计和使用所以的MySQL就是一个人力三轮车。
索引分为单列索引和组合索引。单列索引,即一个索引只包含单个列,一个表可以有多个单列索引,但这不是组合索引。组合索引,即一个索引包含多个列。
创建索引时,你需要确保该索引是应用在sql查询语句的条件(一般作为where子句的条件)。
实际上,索引也是一张表,该表保存了主键与索引字段,并指向实体表的记录。
上面都在说使用索引的好处,但过多的使用索引会造成滥用。因此索引也会有它的缺点:虽然索引大大提高了查询速度,同时却会降低更新表的速度,比如对表进行insert/update和delete.因为更新表时,MySQL不仅要保存数据,还要保存以下索引文件。
建立索引会占用磁盘空间的索引文件。
一、普通索引
(1)创建索引
这是最基本的索引,它没有任何限制。它有以下几种创建方式:

CREATE INDEX indexName ON mytable(username(length));

如果是char,varchar类型,length可以小于字段实际长度;
如果是BLOB和TEXT类型,必须指定length.
(2)修改表结构

ALTER mytable ADD INDEX [indexName] ON (username(length))

(3)创建表的时候直接指定

CREATE TABLE mytable(    ID INT NULL,    username VARCHAR(16) NOT NULL,    INDEX[indexName](username(length)));

(4)删除索引的语法

DROP INDEX[indexName] ON mytable;

二、唯一索引
它与前面的普通索引类似,不同的就是:索引列的值必须唯一,但允许有控制。如果是组合索引,则列值的组合必须唯一。它有以
下几种创建方式:
(1)创建索引

REATE UNIQUE INDEX indexName ON mytable(username(length));

(2)修改表结构

ALTER mytable ADD UNIQUE [indexName] ON (username(length));

(3)创建表的时候直接指定

CREATE TABLE mytable(    ID INT NULL,    username VARCHAR(16) NOT NULL,    UNIQUE [indexName] (username(length)));

三、使用ALTER命令添加和删除索引
有四种方式来添加数据表的索引:
(1)该语句添加一个主键,这意味着索引值必须是唯一的,且不能为NULL。

ALTER TABLE tbl_name ADD PRIMARY KEY (column_list);

(2)这条语句创建索引的值必须是唯一的(除了NULL外,NULL可能出现多次)。

ALTEE TABLE tbl_name ADD UNIQUE index_name (column_list);

(3)添加普通索引,索引值可出现多次。

ALTER TABLE tbl_name ADD INDEX index_name(column_list);

(4)该语句指定了索引为FULLTEXT,用于全文索引。

ALTER TABLE tbl_name ADD FULLTEXT index_name(column_list);

四、显示索引信息
你可以使用SHOW INDEX命令来列出表中的相关的索引信息,可以通过添加\G来格式化输出信息。
实例:

mysql>SHOW INDEX FROM table_name\G
阅读全文
'); })();
0 0
原创粉丝点击
热门IT博客
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 游子吟古诗全文拼音版 游子吟一共8句 游子吟歌颂了什么 游子吟是谁写的 游子吟少儿歌曲 游子吟的故事 游子吟的意思是什么 游子吟 古诗 游子吟 古诗全文 歌曲游子吟儿童歌曲 歌曲游子吟 游子吟的古诗 游子吟儿歌在线试听 游子吟的作者是 游子吟谁写的 游子吟的拼音 游子吟赏析 浮云终日行游子久不至的意思 浮云终日行游子久不至 浮云终日行 游子久不至的意思 澳洲游学团 暑期游学团 美国游学团 超级学团 亲子游学团 曲阜师范大学学团网 现代丹师的古代游 又患无硕师名人与游 热血江湖手游符师攻略 手游设计师 正义红师手游 驭灵师手游 三国群英志手游版 三国英雄志手游 三国群英志手游 三国群英志手游攻略 游学志 菲律宾游学中介 怎么申请游学 国际游学网 游学者声望