”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > MySQL 错误 150 和 1005:为什么我无法创建外键关系?

MySQL 错误 150 和 1005:为什么我无法创建外键关系?

发布于2024-12-21
浏览:487

MySQL Error 150 & 1005: Why Can\'t I Create Foreign Key Relationships?

MySql 外键错误 150: A Puzzling Enigma

当尝试创建具有外键关系的“foo”和“bar”表时,您会遇到与错误 150 有关的错误 1005 (HY000)。此错误可能会令人沮丧,让您感到困惑根本原因。

根据有关 FOREIGN KEY Constraints 的 MySQL 文档,重新创建具有外键引用的已删除表时会出现问题。该表必须通过具有匹配的列名称和类型以及引用键上的索引来符合外键约束。如果不满足这些条件,MySQL 将返回错误 1005,并带有基础错误 150。

您的错误很可能是由于“foo”表未定义为 InnoDB 表所致。 MySQL文档明确指出这两个表必须是InnoDB表并且是非临时表。

通过修改“foo”表创建查询来指定InnoDB引擎:

mysql> CREATE TABLE foo(id INT PRIMARY KEY) ENGINE=InnoDB;

您应该能够使用外键约束成功创建“bar”表,解决错误 150.

最新教程 更多>
  • 如何使用 MySQL 查找今天生日的用户?
    如何使用 MySQL 查找今天生日的用户?
    如何使用 MySQL 识别今天生日的用户使用 MySQL 确定今天是否是用户的生日涉及查找生日匹配的所有行今天的日期。这可以通过一个简单的 MySQL 查询来实现,该查询将存储为 UNIX 时间戳的生日与今天的日期进行比较。以下 SQL 查询将获取今天有生日的所有用户: FROM USERS ...
    编程 发布于2024-12-21
  • 如何在 PHP 中正确使用 INSERT INTO 准备语句?
    如何在 PHP 中正确使用 INSERT INTO 准备语句?
    将准备好的语句与 INSERT INTO 合并在遍历 PHP 的迷宫深度:数据对象时,在尝试执行 MySQL 时出现了一个令人困惑的难题使用准备好的语句进行查询,特别是用于 INSERT INTO 操作。考虑以下代码片段:$statement = $link->prepare("IN...
    编程 发布于2024-12-21
  • 为什么 `Class object();` 不创建 C++ 对象?
    为什么 `Class object();` 不创建 C++ 对象?
    理解构造函数调用的缺失在 C 中,构造函数用于初始化类的对象。然而,在提供的代码片段中,构造函数没有被调用,导致意外的行为。问题有问题的行:Class object();实际上并不调用 Class 类的构造函数。相反,它声明一个返回 Class 对象的函数。要正确调用构造函数并创建对象,必须在行后附...
    编程 发布于2024-12-21
  • PHP 中的静态类与实例化类:何时选择什么?
    PHP 中的静态类与实例化类:何时选择什么?
    PHP 中的静态类与实例化类理解静态类和实例化类之间的区别在面向对象编程中至关重要。 PHP 作为一种流行的面向对象语言,提供了这两种选择。本文旨在阐明它们的适当用法。区别和适用性静态类与实例化对象不同,不保存特定数据并且不能复制。它们用作执行特定任务而不维护实例状态的实用函数。另一方面,实例化对象...
    编程 发布于2024-12-21
  • ES6 计算属性如何解决动态对象初始化挑战?
    ES6 计算属性如何解决动态对象初始化挑战?
    在 ES6 的对象初始化中使用动态属性名称在编程中经常会出现使用从外部源派生的属性名称创建对象的挑战。在查询中描述的场景中,我们尝试构造一个 JavaScript 对象,其属性的键在单独的变量 KEYS 中定义。但是,在为对象内的属性赋值时,我们遇到错误由于使用了点运算符 (.)。该运算符是为文字对...
    编程 发布于2024-12-21
  • 大批
    大批
    方法是可以在对象上调用的 fns 数组是对象,因此它们在 JS 中也有方法。 slice(begin):将数组的一部分提取到新数组中,而不改变原始数组。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index p...
    编程 发布于2024-12-21
  • 为什么 Margin Top 不适用于 CSS 中的内联元素?
    为什么 Margin Top 不适用于 CSS 中的内联元素?
    顶部边距和内联元素在 CSS 中,margin 属性用于定义元素边框之外的间距。然而,在内联元素上使用 margin top 时会出现一个常见问题,特别是在 Firefox 中。问题:为什么内联元素的 margin top 似乎被忽略在 Firefox 中?答案:此行为并非 Firefox 独有,而...
    编程 发布于2024-12-21
  • 如何使用XPath通过CSS类高效定位HTML元素?
    如何使用XPath通过CSS类高效定位HTML元素?
    使用 XPath 按 CSS 类查找元素在网页抓取中,通常需要根据 CSS 类来定位 HTML 元素。 XPath 是一个用于导航 XML 和 HTML 文档的强大工具,它提供了一种实现此目的的方法。考虑一个 HTML 页面,其中的 div 元素具有名为“Test”的类。以下 XPath 查询可用于...
    编程 发布于2024-12-21
  • 尽管代码有效,为什么 POST 请求无法捕获 PHP 中的输入?
    尽管代码有效,为什么 POST 请求无法捕获 PHP 中的输入?
    解决 PHP 中的 POST 请求故障在提供的代码片段中:action=''而不是:action="<?php echo $_SERVER['PHP_SELF'];?>";?>"检查 $_POST数组:表单提交后使用 var_dump 检查 $_POST 数...
    编程 发布于2024-12-21
  • 为什么 `array_shift()` 会触发“严格标准:只有变量应该通过引用传递”?
    为什么 `array_shift()` 会触发“严格标准:只有变量应该通过引用传递”?
    错误信息“Strict Standards: Only Variables Should Be Passed by Reference”使用 array_shift() 时,可能会报告严格标准如果传递的参数是函数调用的结果,则会发出警告。这种行为看起来不一致,因为它并不总是触发警告。考虑以下代码:$...
    编程 发布于2024-12-21
  • 如何在 Pandas 中进行聚合?
    如何在 Pandas 中进行聚合?
    Pandas 中的聚合如何使用 Pandas 执行聚合?聚合函数会降低返回对象的维度。一些常见的聚合函数包括mean()、sum()、size()、count()、std()、var()和sem()。df1 = df.groupby(['A', 'B'], as_index=False)['C']....
    编程 发布于2024-12-21
  • 如何在 C++ 中初始化静态 `const std::string` 数据成员?
    如何在 C++ 中初始化静态 `const std::string` 数据成员?
    声明 const std::string 类型的静态数据成员在 C 中,直接在类定义中初始化 const std::string 类型的静态数据成员是不允许。相反,有两个选项可以定义此类数据成员:内联变量(C 17 或更高版本)使用内联变量,它定义并初始化类定义中的静态成员:class A { pr...
    编程 发布于2024-12-21
  • 如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    MySQL配置不正确:相对路径的问题在Django中运行python manage.py runserver时,可能会遇到以下错误:ImproperlyConfigured: Error loading MySQLdb module: dlopen(/Library/Python/2.7/site-...
    编程 发布于2024-12-21
  • 如何在 Python 中从函数内部获取函数名称?
    如何在 Python 中从函数内部获取函数名称?
    从函数内部访问函数名称在 Python 中,从函数本身内部确定函数名称在动态自省的情况下非常有用inspect 模块提供了一种方便的机制来获取有关正在运行的程序代码的信息。使用inspect.stack(),我们可以访问表示当前调用堆栈的帧列表。对于给定的函数,堆栈列表中的第一帧对应于当前函数,而第...
    编程 发布于2024-12-21
  • 如何将电子表格列索引号转换为其等效字母?
    如何将电子表格列索引号转换为其等效字母?
    将电子表格列索引转换为字母在 Google 表格中,列用数字索引,从 1 开始。但是,为了方便起见,它们通常也使用字母来表示(例如,“A”表示第一列,“D”表示第四列)。数字索引和字母值之间的转换通常是脚本任务所必需的。实现此转换的一种方法是通过以下函数:function getColumnLett...
    编程 发布于2024-12-21

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3