一、索引
索引的优势:可以快速检索,减少I/O次数,加快检索速度;根据索引分组和排序,可以加快分组和排序。
索引的劣势:索引本身也是表,因此会占用存储空间,一般来说,索引表占用的空间是数据表的1.5倍;索引表的维护和创建需要时间成本,这个成本随着数据量增大而增大;构建索引会降低数据表的修改操作(删除,添加,修改)的效率,因为在修改数据表的同时还需要修改索引表。
索引可以在创建表时创建,也可以在创建表之后添加。
在创建表时创建索引,代码如下所示:

– 建表
 create table mytable(
 id int not null,
 username varchar(16) not null,
 index myindex(username(16))
 );
 – index —— 关键词
 – myindex —— 自定义名字
 – 要添加到那个字段上
 已经创建表后添加索引
 – 创建索引
 create index myindex on mytable(username(16));
 – 或者
 alter table mytable add index myindex(username);
 删除索引:
 – 删除索引
 drop index myindex onmytable;
 – 或者
 alter table mytable drop index myindex;


二、事务
事务的隔离级别有4个:
读未提交(readuncommitted):事务A和事务B,事务A未提交的数据,事务B可以读取到,这里读取到的数据叫做“脏数据”。这种隔离级别最低,一般是在理论上存在,数据库隔离级别一般都高于该级别;
读已提交(readcommitted):事务A和事务B,事务A提交的数据,事务B才能读取到。这种隔离级别高于读未提交,可以避免“脏数据”。但如果事务A多次读取同一数据,而事务B在事务A多次读取的过程中,对数据作了更新并提交,导致事务A多次读取同一数据时,结果不一致,这种现象称为“不可重复读”;
可重复读(repeatableread):事务A和事务B,事务A提交之后的数据,事务B读不到事务A提交的数据。这种隔离级别高于读已提交,但如果事务A在修改数据的过程中(比如将所有记录状态设为1),如果事务B向同一张表中插入一条新记录(状态为0),事务A提交后再次查询表,会发现有一条记录状态没有改成1,好像发生了幻觉,这种现象称为“幻读”。可重复读是MySQL默认隔离级别;
串行化(serializable):事务A和事务B,事务A在操作数据库时,事务B只能排队等待。这种级别可以避免“幻读”,每一次读取的都是数据库中真实存在数据,事务A与事务B串行,而不并发。