MySql高级

索引

  1. 什么是索引
    方便快速查询成百上万条数据
    效率高
  2. 索引的优劣势
    优势
    快速检索,效率更高
    劣势
    占用内存大
  3. 索引的使用
    语法
    creat index
    案例
    ##创建表添加索引
`CREA`TE TABLE mytable(
			id int not NULL,
			username VARCHAR(20) not NULL,
			INDEX myindex(username(20))
				)
		查看命令
			show index from 表名
		删除
			drop index  索引名字 on 表名
	##建表之后添加索引
		create index 索引名 on 表名 (列名(列名长度))
  1. 分类
    分类
    主键索引
    唯一索引
  2. 规则
    适合
    经常作为查询条件在 WHERE 或者 ORDER BY 语句中出现的列要
    不适合
    经常增删改的列不要建立索引;
    有大量重复的列不建立索引

事务

  1. 什么是事务
    事务(Transaction):一个最小的不可再分的工作单元;通常一个事务对应一个完整的业务(例如银行账户转
    账业务,该业务就是一个最小的工作单元)。
  2. 步骤
    开启
**start tranction**
提交	
**commit**
回滚 
**rollback**
  1. 特性
    原子性(A):事务是最小单位,不可再分;
    一致性©:事务要求所有的 DML 语句操作的时候,必须保证同时成功或者同时失败;
    隔离性(I):同一时间,只允许一个事务请求同一数据,不同的事务之间彼此没有任何干扰
    持久性(D):是事务的保证,事务终结的标志(内存的数据持久到硬盘文件中)。

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

你可能感兴趣的:(mysql)