文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

MySQL 储存引擎 MyISAM 和 InnoDB 配置

2024-04-02 19:55

关注

MySQL 存储引擎 MyISAM 和 InnoDB 配置


MyISAM 和 InnoDB 最大特点:

MyISAM :

① 不支持事务 。

② 表级锁定形式 ,数据在更新时锁定整个表 。

③ 不支持外键约束 ,只支持全文索引 。

④ 数据库在读取过程中相互阻塞 。

⑤ 数据单独写入或读取 , 速度较快且占用资源相对要少 。

InnoDB:

① 支持事务 。

② 行级锁定 ,但是全表扫描仍然会是表级锁定 。

③ 支持分区、表空间 ,类似Oracle 数据库 。

④ 读写阻塞与事务隔离级别相关 。

⑤ 表与主键以簇的方式储存 。

⑥ 具有非常高效的缓存特性 ,能缓存引索 ,也能缓存数据 。

如何查看存储引擎:

查看 MySQL 默认存储引擎 :
mysql> show engines;
+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
| Engine             | Support | Comment                                                        | Transactions | XA   | Savepoints |
+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
| InnoDB             | DEFAULT | Supports transactions, row-level locking, and foreign keys     | YES          | YES  | YES      
查看 MySQL 支持的引擎以及默认存储引擎 。

查看表正在使用的存储引擎 :

方法一:
show table status from 库名 where name='表名';
mysql> show table status from jdy where name='test';
+------+--------+---------+------------+------+
| Name | Engine | Version | Row_format | Rows |
+------+-------------+-----------------+--------------+
| test | InnoDB |      10 | Dynamic    |    0 |                 # 表的存储引擎  InnoDB
方法二:
show create table 表名;
mysql> use jdy;          # 进入查看表的数据库
Database changed
mysql> show create table test;
+-------+---------------------------------------------------------------------------------------------------------------------------+
| Table | Create Table                                                                                                              |
+-------+---------------------------------------------------------------------------------------------------------------------------+
| test  | CREATE TABLE "test" (
 "name" varchar(10) DEFAULT NULL,
  "id" int(11) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8 |          # 表的存储引擎  InnoDB

如何修改存储引擎:

mysql> use jdy;          # 进入查看表的数据库
Database changed
mysql> show create table test;
+-------+---------------------------------------------------------------------------------------------------------------------------+
| Table | Create Table                                                                                                              |
+-------+---------------------------------------------------------------------------------------------------------------------------+
| test  | CREATE TABLE "test" (
 "name" varchar(10) DEFAULT NULL,
  "id" int(11) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8 |          # 表的存储引擎  InnoDB

#命令: alter table 表名 engine=引擎; 

mysql> alter table test engine=MyISAM;       #修改表的存储引擎为 MyISAM
Query OK, 0 rows affected (0.39 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> show create table test;
+-------+---------------------------------------------------------------------------------------------------------------------------+
| Table | Create Table                                                                                                              |
+-------+---------------------------------------------------------------------------------------------------------------------------+
| test  | CREATE TABLE "test" (
  "name" varchar(10) DEFAULT NULL,
  "id" int(11) DEFAULT NULL
) ENGINE=MyISAM DEFAULT CHARSET=utf8 |            #修改成功

方法二 :

vim /etc/my.cnf
[mysqld]
default-storage-engine=MyISAM   #添加指定默认存储引擎
mysql> create table test01 (id int );     #创建表
Query OK, 0 rows affected (0.00 sec)

mysql> show create table test01;
+--------+------------------------------------------------------------------------------------------+
| Table  | Create Table                                                                             |
+--------+------------------------------------------------------------------------------------------+
| test01 | CREATE TABLE "test01" (
  "id" int(11) DEFAULT NULL
) ENGINE=MyISAM DEFAULT CHARSET=utf8 |       #创建的新表默认 MyISAM
设置默认存储引擎 ,创建的新表将使用 MyISAM 存储引擎 。

方法三 :

mysql> create table test02 (id int ) engine=InnoDB;
Query OK, 0 rows affected (0.35 sec)
mysql> show create table test02;
+--------+------------------------------------------------------------------------------------------+
| Table  | Create Table                                                                             |
+--------+------------------------------------------------------------------------------------------+
| test02 | CREATE TABLE "test02" (
  "id" int(11) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8 |         #新表存储引擎是 InnoDB

方法四:

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯