mysql8.026创建表时innodb层面加索引文件流程以及 Table storage engine for ‘t4‘ doesn‘t have this option 底层代码调用流程

在这里插入图片描述sql/handler.cc文件里创建表流程(create函数最终调用到nnodb.cc中create函数),innodb流程见下图
在这里插入图片描述mysql在innodb.cc创建表的流程
在这里插入图片描述

![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/46659eaad08c46b3ba7b23037aeddde7.png
mysql出现1031错误码(ERROR 1031 (HY000): Table storage engine for ‘t4’ doesn’t have this option)底层代码调用,例如sql:create table t4(id int not null,name varchar(30)) ENGINE = InnoDB partition by range (id) ( partition p0 values LESS THAN (10) index directory = ‘test’); 中不支持index directory = ‘test’。

  • 10
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
第一个错误提示说明你运行的 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、付费专栏及课程。

余额充值