mysql引擎基础了解

一、Mysql两种引擎的区别

          (1):MyISAM存储引擎:不支持事务、也不支持外键,优势是访问速度快,对事务完整性没有 要求或者以select,insert为主的应用基本上可以用这个引擎来创建表
支持3种不同的存储格式,分别是:静态表;动态表;压缩表
静态表:表中的字段都是非变长字段,这样每个记录都是固定长度的,优点存储非常迅速,容易缓存,出现故障容易恢复;缺点是占用的空间通常比动态表多(因为存储时会按照列的宽度定义补足空格)ps:在取数据的时候,默认会把字段后面的空格去掉,如果不注意会把数据本身带的空格也会忽略。
动态表:记录不是固定长度的,这样存储的优点是占用的空间相对较少;缺点:频繁的更新、删除数据容易产生碎片,需要定期执行OPTIMIZE TABLE或者myisamchk-r命令来改善性能
压缩表:因为每个记录是被单独压缩的,所以只有非常小的访问开支
(2)InnoDB存储引擎*
该存储引擎提供了具有提交、回滚和崩溃恢复能力的事务安全。但是对比MyISAM引擎,写的处理效率会差一些,并且会占用更多的磁盘空间以保留数据和索引。
InnoDB存储引擎的特点:支持自动增长列,支持外键约束。

  二、 总结

简单介绍区别:

1、MyISAM是非事务安全的,而InnoDB是事务安全的

2、MyISAM锁的粒度是表级的,而InnoDB支持行级锁

3、MyISAM支持全文类型索引,而InnoDB不支持全文索引

4、MyISAM相对简单,效率上要优于InnoDB,小型应用可以考虑使用MyISAM

5、MyISAM表保存成文件形式,跨平台使用更加方便

三、应用场景:

1、MyISAM管理非事务表,提供高速存储和检索以及全文搜索能力,如果再应用中执行大量select操作,应该选择MyISAM
2、InnoDB用于事务处理,具有ACID事务支持等特性,如果在应用中执行大量insert和update操作,应该选择InnoDB

 

如何查看当前mysql的存储引擎

         mysql现在已提供什么存储引擎: show engines;

        mysql当前默认的存储引擎: show variables like '%storage_engine%';

        某个表用了什么引擎(在显示结果里参数engine后面的就表示该表当前用的存储引擎):

             show create table 表名;

修改mysql的默认存储引擎

             

1、查看mysql存储引擎命令,

在mysql>提示符下搞入show engines;

字段 Support为:Default表示默认存储引擎  

 2、 设置InnoDB为默认引擎:

         找到mysql安装的地方,my.ini配置配件打开加入

default-storage-engine=INNODB

3、重启mysql服务器:

mysql admin -u root -p shutdown

或者service mysqld restart 登录mysql数据库

MySQL查看和修改表的存储引擎

查看表使用的存储引擎

两种方法:

                 a、show table status from db_name where name='table_name';

                 b、show create table table_name;

3 、修改表引擎方法

                alter table table_name engine=innodb;

4、 关闭Innodb引擎方法

                 关闭mysql服务: net stop mysql

                  找到mysql安装目录下的my.ini文件:

                   找到default-storage-engine=INNODB 改为default-storage-engine=MYISAM

                   找到#skip-innodb 改为skip-innodb

                   启动mysql服务:net start mysql

 

 


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值