什么是存储引擎:
数据的存储方式
同样的数据,对你来说也是同样的表,只不过指定不同的存储引擎,代表了数据在存储的时候不同方式
mysql有几种存储引擎:
有多重不同的存储引擎
mysql有何多种存储数据的方式,来帮助我们适应个中 场景来进行数据操作
有的时候我们对数据的存取速度要求很高,但是对数据的稳定性要求没有那么高
有得时候我们队数据的查询熟读要求高,但是对修改和删除的效率要求没有那么高
有的时候我们需要建立表与表之间的联系
mysql存储引擎的种类:
InnoDB : 5.6版本
MyISAM : 5.5 版本 MYISAM
MEMORY :
BLACKHOLE:
事物支持:
事务 让多条mysql语句编程一个整体,要成功一起成功,如果其中有一条语句失败了,那么得状态都要回归到开始事物之前
外键:
突出了表与表之间的联系
索引:
比喻的是 这个东西的目录 能够帮助我们加快查询速度
内存的高速缓冲 cache:
把一部分数据放到内存中
常用存储引擎及使用场景:
InnoDB
用于事务处理应用程序,支持外键和行级锁。如果应用对事物的完整性有比较高的要求,在并发条件下要求数据的一致性,数据操作除了插入和查询之外,还包括很多更新和删除操作,那么InnoDB存储引擎是比较合适的。InnoDB除了有效的降低由删除和更新导致的锁定,还可以确保事务的完整提交和回滚,对于类似计费系统或者财务系统等对数据准确要求性比较高的系统都是合适的选择。
MyISAM
如果应用是以读操作和插入操作为主,只有很少的更新和删除操作,并且对事务的完整性、并发性要求不高,那么可以选择这个存储引擎。
Memory
将所有的数据保存在内存中,在需要快速定位记录和其他类似数据的环境下,可以提供极快的访问。Memory的缺陷是对表的大小有限制,虽然数据库因为异常终止的话数据可以正常恢复,但是一旦数据库关闭,存储在内存中的数据都会丢失。
存储引擎mysql的相关操作:
show variables; #查看mysql的全部属性
默认的存储引擎:
show variables like 'default_storage_engine';
查看我支持的默认引擎;
show engines;
创建一个库
切换到这个库
创建一个表在这个库里面设置字段
create table innodb_t(id int);