作为dba,myisam和innodb的不同?


作为DBA,MyISAM和InnoDB的不同点主要体现在以下方面: 1. 存储结构:每个MyISAM在磁盘上存储了三个文件,包括表的定义文件(.frm)、数据文件(.MYD)和索引文件(.MYI)。而InnoDB在磁盘上存储了两个文件,包括表的定义文件(.frm)以及数据和索引文件(.ibd)。 2. 存储空间:MyISAM存储空间相对较小,而InnoDB需要更多的内存和存储空间。MyISAM支持三种存储模式,包括静态表、动态表、压缩表,而InnoDB不支持压缩。 3. 事务支持:MyISAM注重效率,每次查询具有原子性,执行速度比InnoDB快一些,但并不支持事务操作。InnoDB支持事务提交、事务回滚等高级数据库操作,安全性较高。 4. 锁的支持:MyISAM只支持表锁,需要锁定整个表格,效率相对较低。而InnoDB支持行锁,只需要锁定某一行,效率较高。 5. 外键支持:MyISAM不支持外键,而InnoDB支持外键。 6. 主键观念:MyISAM可以不定义主键,如果定义了主键,则会是主键索引。InnoDB则必须要有主键,就算没有定义,也会自动创建一个隐藏的6byte的int型的索引。 作为DBA,要根据实际应用场景选择合适的存储引擎。如果需要执行大量的查询,且注重效率,可以选择MyISAM;如果需要执行增、删、改等操作较多,且需要支持事务等高级数据库操作,可以选择InnoDB。 [2023-11-09 18:00:23 | AI写代码神器 | 350点数解答]
相关提问
- 作为dba,myisam 静态和 myisam 动态有什么区别?(268点数解答 | 2023-11-09 18:05:06)161
- 作为dba,mysql常见的三种存储引擎(innodb、myisam、memory)的区别?(378点数解答 | 2023-11-09 18:01:16)170
- 作为dba,简述mysql innodb 的读写参数优化 ?(582点数解答 | 2023-11-09 18:10:50)113
- create table user application form( id`int not null auto increment, `name` varchar(50)default null comment'用户名', `gender`int default'2'comment'性别,默认2,男0女1 phone`varchar(50)default null comment'手机号' state`int default'0'comment'审核状态,默认0申请中 1审核通过-1审核失败' `mark` varchar(255)default null comment'备注' created_at`datetime default current timestamp comment 创建时间' updated_at`datetime default current timestamp comment '更新时间' primary key (`id`) engine=innodb comment='用户申请单';(269点数解答 | 2024-12-03 11:49:17)178
- 数据库表结构: 我们已经有以下的数据库表结构来存储书籍信息: create table `books` ( `id` int(11) not null auto_increment, `title` varchar(255) not null, `author` varchar(255) not null, `price` decimal(10, 2) not null, `stock` int(11) not null, primary key (`id`) ) engine=innodb default charset=utf8mb4; 1. 请编写一个bookcontroller 包含方法findall(),该方法使用 @responsebody 注解返回一个包含书籍信息的 list对象,并确保返回的是json格式。 2. 编写一个 bookservice 接口定义了findall()方法,用于查询所有书籍。现在需要新建实现类 bookserviceimpl, 并实现findall()方法,将bookserviceimpl注入到控制器中 3. 编写数据(651点数解答 | 2024-12-08 14:19:12)272
- 数据库表结构: 我们已经有以下的数据库表结构来存储书籍信息: create table `books` ( `id` int(11) not null auto_increment, `title` varchar(255) not null, `author` varchar(255) not null, `price` decimal(10, 2) not null, `stock` int(11) not null, primary key (`id`) ) engine=innodb default charset=utf8mb4; 1. 请编写一个bookcontroller 包含方法findall(),该方法使用 @responsebody 注解返回一个包含书籍信息的 list对象,并确保返回的是json格式。 2. 编写一个 bookservice 接口定义了findall()方法,用于查询所有书籍。现在需要新建实现类 bookserviceimpl, 并实现findall()方法,将bookserviceimpl注入到控制器中 3. 编写数据库访问接口bookmappe(254点数解答 | 2024-12-08 14:23:56)299
- 数据库表结构: 我们已经有以下的数据库表结构来存储书籍信息: create table `books` ( `id` int(11) not null auto_increment, `title` varchar(255) not null, `author` varchar(255) not null, `price` decimal(10, 2) not null, `stock` int(11) not null, primary key (`id`) ) engine=innodb default charset=utf8mb4; 1.请编写一个bookcontroller 包含方法findall(),该方法使用 @responsebody 注解返回一个包含书籍信息的 list对象,并确保返回的是json格式。 2.请编写一个 bookservice 接口定义了findall()方法,用于查询所有书籍。现在需要新建实现类 bookserviceimpl, 并实现findall()方法,将bookserviceimpl对象注入到控制器中 3.请编写数(254点数解答 | 2024-12-13 08:25:28)191
- 数据库表结构: 我们已经有以下的数据库表结构来存储书籍信息: create table `books` ( `id` int(11) not null auto_increment, `title` varchar(255) not null, `author` varchar(255) not null, `price` decimal(10, 2) not null, `stock` int(11) not null, primary key (`id`) ) engine=innodb default charset=utf8mb4; 1.请编写一个bookcontroller 包含方法findall(),该方法使用 @responsebody 注解返回一个包含书籍信息的 list对象,并确保返回的是json格式。 2.请编写一个 bookservice 接口定义了findall()方法,用于查询所有书籍。现在需要新建实现类 bookserviceimpl, 并实现findall()方法,将bookserviceimpl对象注入到控制器中 3.请编写数(982点数解答 | 2024-12-13 08:35:05)174
- 数据库表结构: 我们已经有以下的数据库表结构来存储书籍信息: create table `books` ( `id` int(11) not null auto_increment, `title` varchar(255) not null, `author` varchar(255) not null, `price` decimal(10, 2) not null, `stock` int(11) not null, primary key (`id`) ) engine=innodb default charset=utf8mb4; 1.请编写一个bookcontroller 包含方法findall(),该方法使用 @responsebody 注解返回一个包含书籍信息的 list对象,并确保返回的是json格式。 2.请编写一个 bookservice 接口定义了findall()方法,用于查询所有书籍。现在需要新建实现类 bookserviceimpl, 并实现findall()方法,将bookserviceimpl对象注入到控制器中 3.请编写数据库访问接口bookmapp(340点数解答 | 2024-12-13 08:41:55)148
- 数据库表结构: 我们已经有以下的数据库表结构来存储书籍信息: create table `books` ( `id` int(11) not null auto_increment, `title` varchar(255) not null, `author` varchar(255) not null, `price` decimal(10, 2) not null, `stock` int(11) not null, primary key (`id`) ) engine=innodb default charset=utf8mb4; 1.请编写一个bookcontroller 包含方法findall(),该方法使用 @responsebody 注解返回一个包含书籍信息的 list对象,并确保返回的是json格式。 2.请编写一个 bookservice 接口定义了findall()方法,用于查询所有书籍。现在需要新建实现类 bookserviceimpl, 并实现findall()方法,将bookserviceimpl对象注入到控制器中 3.请编写数据库访问接口bookmapp(983点数解答 | 2024-12-13 08:43:29)171
- CREATE TABLE `categories` ( `id` bigint unsigned NOT NULL AUTO_INCREMENT, `name` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL COMMENT '分类名称', `parent_id` bigint NOT NULL COMMENT '父分类ID', `description` text COMMENT '分类描述', `created_by` bigint NOT NULL COMMENT '创建者ID', `created_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', `updated_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '更新时间', PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET(1733点数解答 | 2025-06-18 01:54:30)98
- 作为**工程师,作为**工程师如何做到不漏测?(386点数解答 | 2023-11-09 18:25:11)269