Unknown table engine ‘InnoDb’的解决办法

今天mysql碰到“Unknown table engine ‘InnoDb’”问题

 

提示信息明显,缺少InnoDb数据库引擎。

命令行下查看一下可用数据库引擎:

 

mysql> show engines;
+————+———+————
| Engine     | Support | Comment …
+————+———+————
| MEMORY     | YES     | …
| FEDERATED  | NO      |
| MyISAM     | DEFAULT |
| BLACKHOLE  | YES     |
| MRG_MYISAM | YES     |
| CSV        | YES     |
| ARCHIVE    | YES     |
| InnoDB     | NO      |
+————+———+-
8 rows in set (0.00 sec)

确实是InnoDB引擎没启用。

解决办法有二:

1、修改SQL语句中的引擎InnoDB为MyISAM,一般MyISAM都是启用的。

2、修改MySQL安装目录下的my.ini,在skip-innodb前增加#,重启MySQL:

在my.ini 中把 innodb_buffer_pool_size = 512M,配置大点,就ok了

 

第一个错误提示说明你运行的 SQL 脚本文件中使用了 InnoDB 存储引擎,但是该引擎可能没有被安装或者被禁用了。你可以通过执行`SHOW ENGINES;`语句来查看当前 MySQL 数据库支持的存储引擎列表,如果 InnoDB 不在列表中,那么你需要启用 InnoDB 引擎。你可以在 MySQL 配置文件中添加或修改以下配置: ``` [mysqld] default-storage-engine=InnoDB innodb_file_per_table=1 innodb_buffer_pool_size=XXG # 根据你的实际情况设置合适的内存大小 ``` 其中,`default-storage-engine`配置项用于指定默认的存储引擎InnoDB,`innodb_file_per_table`配置项用于指定每个 InnoDB 表使用独立的表空间,`innodb_buffer_pool_size`配置项用于指定 InnoDB 缓冲池的大小。 第二个错误提示说明你的 SQL 脚本文件中涉及到了一个名为 xuesheng 的表,但是该表可能不存在。你可以通过执行`SHOW TABLES;`语句来查看当前数据库中存在的表,如果 xuesheng 不在列表中,那么你需要创建该表。你可以执行以下 SQL 语句来创建 xuesheng 表: ``` CREATE TABLE xuesheng ( id INT UNSIGNED NOT NULL AUTO_INCREMENT, name VARCHAR(30) NOT NULL, age TINYINT UNSIGNED NOT NULL, sex ENUM('男', '女') NOT NULL, PRIMARY KEY (id) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; ``` 其中,`id`字段为自增字段,`name`字段为字符串类型,`age`字段为无符号的小整数类型,`sex`字段为枚举类型。注意,这里的存储引擎也是 InnoDB
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值