首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

laravel 5.4迁移errno: 150“外键约束形式不正确”

Laravel 5.4迁移errno: 150“外键约束形式不正确”是一个常见的错误,通常在数据库迁移过程中出现。这个错误表示外键约束的形式不正确,可能是由于以下几个原因导致的:

  1. 表之间的关联关系定义错误:在Laravel中,使用迁移来定义数据库表之间的关联关系是很常见的。当定义外键约束时,需要确保表之间的关联关系正确,并且外键字段的数据类型和长度与关联表的主键字段一致。
  2. 表的创建顺序不正确:如果在迁移文件中创建表的顺序不正确,可能会导致外键约束的错误。确保先创建被引用的表,再创建引用该表的表。
  3. 字段类型不匹配:外键字段的数据类型和长度必须与关联表的主键字段完全匹配。如果数据类型或长度不匹配,就会出现外键约束错误。

解决这个问题的方法包括:

  1. 检查迁移文件中的关联关系定义,确保关联关系正确,并且外键字段的数据类型和长度与关联表的主键字段一致。
  2. 检查迁移文件的创建顺序,确保先创建被引用的表,再创建引用该表的表。
  3. 检查外键字段的数据类型和长度,确保与关联表的主键字段完全匹配。

如果以上方法都没有解决问题,可以尝试以下步骤:

  1. 删除相关的迁移文件:如果出现错误的迁移文件,可以尝试删除相关的迁移文件,并重新创建正确的迁移文件。
  2. 重置数据库:可以使用Laravel的迁移重置命令来重置数据库,然后再运行迁移命令。
  3. 检查数据库引擎:确保数据库引擎支持外键约束。有些数据库引擎默认是不支持外键约束的,需要手动设置。

对于laravel 5.4迁移errno: 150“外键约束形式不正确”的问题,腾讯云提供了一系列的云数据库产品,如腾讯云数据库MySQL、腾讯云数据库MariaDB等,可以满足各种规模和需求的应用场景。您可以通过腾讯云官方文档了解更多关于腾讯云数据库产品的信息和使用方法:

腾讯云数据库MySQL:https://cloud.tencent.com/document/product/236

腾讯云数据库MariaDB:https://cloud.tencent.com/document/product/1003

请注意,以上答案仅供参考,具体解决方法可能因实际情况而异。建议您在遇到问题时,参考官方文档或向相关技术社区寻求帮助。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • Laravel 通过迁移文件定义数据表结构

    修改表字段,接下来我们要讨论如何对表字段设置索引和。...所谓键指的是一张表的字段 A 引用另一张表的字段 B,那么字段 A 就是,通过可以建立起两张表之间的关联关系,这样,数据表之间就是有关联的了,而不是一个个孤立的数据集。...('id')->on('users'); 如果你还想进一步指定约束(级联删除和更新,比如我们删除了 users 表中的某个 id 对应记录,那么其在文章表中对应 user_id 的所有文章会被删除...'); 注:不推荐使用,更不要使用约束功能,因为影响数据库性能,而且级联删除有可能造成非常严重的无法挽回的后果。...回滚要稍微复杂点,Laravel 支持多种形式的回滚,如果只回滚最后一个迁移文件的变更,可以通过: php artisan migrate:rollback 来实现,如果要回滚多个迁移文件的变更,可以通过

    2.1K21

    3分钟短文:书接上回,Laravel数据库迁移的那些个小技巧

    引言 使用laravel的数据库迁移功能进行表的创建,和迁移回滚之后,我们继续说说在设计中 表结构的更改之后的处理。以及如何为数据库填充一些伪数据作为测试。...[图片] 数据约束 上一章说到数据库迁移回滚,可以手动控制回滚到哪一批次的迁移位置。...我们需要空与非空约束,默认值约束,主键约束约束等等数据库所具有的特性, 这才是关系型数据库的魅力。...大家应该不陌生SQL语句追加字段的语法: ALTER TABLE contacts ADD last_name varchar(40) NOT NULL AFTER contact_id; laravel...写在最后 本文是对上一章所述laravel数据库迁移功能的补充。数据库迁移是一个比较大的动作, 特别是已经上线生产的应用数据库,如果非到更新迁移的地步不可,需要预期做好演练, 以应对可能的突发事故。

    1.7K30

    laravel-nestedset:多级无限分类正确姿势

    laravel-nestedset是一个关系型数据库遍历树的larvel4-5的插件包 目录: Nested Sets Model简介 安装要求 安装 开始使用 迁移文件 插入节点 获取节点 删除节点...嵌套集合模型 安装要求 PHP>=5.4 laravel>=4.1 v4.3版本以后支持Laravel-5.5 v4版本支持Laravel-5.2、5.3、5.4 v3版本支持Laravel-5.1 v2...版本支持Laravel-4 强烈建议使用支持事物功能的数据引擎(像MySql的innoDb)来防止可能的数据损坏。...insertAfterNode($neighbor); $node->insertBeforeNode($neighbor); 将数组构建为树 但使用create静态方法时,它将检查数组是否包含children,...() 检查一致性 你可以检查树是否被破环 $bool = Category::isBroken(); 获取错误统计: $data = Category::countErrors(); 它将返回含有一下的数组

    3.5K20

    还得再来聊聊Laravel中的对多对模型的一些事

    前言 之前,在文章:https://www.misiyu.cn/article/58.html 已经发过关于Laravel中的多对多关系了。 但回过头来,过了个把月再去看,我自己都忘了怎么写了。...确实看laravel的中文文档,看得糊里糊涂的。还是得在实践中理解啊。 情景假设 我有一张来源表(referers)来记录href和网页标题title。...细节 新建迁移文件就不说了。 我想说的重点是: 1、来源表和信息表可以没有任何约束,意思就是说各建各的,不用考虑什么的。...2、这两表没有任何关联,如果还要产生关系,那么就要第三张表来帮他们建立联系。 以上两点需要特别理解好 ---- 我前面说了,两张表(信息表、来源表)没有任何关系,那么就随便按需求建立就行。...重点是第三张表,第三张表最少需要2个字段:即两张表的 ? 注意: 1、你想要有其他字段也行,我们这里讨论最简单的情况。 2、第三张表的命名有要求,主要是Laravel默认情况的关系。

    1.6K00

    Laravel学习记录--数据库迁移

    laravel 数据库迁移 数据迁移文件存放在database/migrations 特点:可进行版本回退,便于团队开发 通过数据迁移文件创建表 1 创建数据库 配置.env文件选择数据库 DB_CONNECTION...此时数据库并没有生成数据表c.我们需要编辑迁移文件,设置相应字段 在使用 php artisan migrate 成功生成表 数据库迁移文件 在这个文件有 up/...change() 重命名字段 $table->renameColumn('from','to') 删除字段 dropCloumn('字段名') dropCloumn(['字段名','字段2']) 约束...当前表从表字段')->references('参考表主表字段')->on('主表') ->onDelete('cascade')//级联删除 ->update('cascade')//级联更新 默认的键名...数据表名称_字段_foreign 删除外 dropForeign('键名') 开启/关闭约束 Schema::enableForeignKeyConstraints() Schema

    1.1K20

    MySQL 学习笔记(三):完整性和触发器设计

    添加约束 alter table 从表 add constraint 约束名(形如:FK_从表_主表) foreign key(属性名) references 主表(属性名) alter table...约束 + 级联(删除/更新) alter table 从表 add constraint 约束名 foreign key(属性名) references 主表(属性名)  ON DELETE CASCADE...删除约束 删除主键约束:alter table 表名 drop primary key; 删除外约束:alter table 表名 drop foreign key (区分大小写);.../school/student' (errno: 150 - Foreign key constraint is incorrectly formed) 查了下资料,发现 MySQL建立的字段必须和引用表的字段一模一样的类型...这里我创建的时候 sno 中有些表有主键约束,有些却没有,所以当我删除主键约束的时候它会提示被错误建立起来了。但我不明白为什么建立的时候没有报错。

    1.5K40

    Laravel 模型关联基础教程详解

    Laravel 中定义模型关联是每个 Laravel 开发者可能已经做过不止一次的事情。但是在试图实现关联时可能会遇到各种问题。因为 Laravel 有各种各样的关联,你应该选择哪一个?...我们通过 hasOne 方法告诉 Laravel User 模型有一个 Passport 。 注意: 所有用于定义关联的方法都有可选的额外参数,你可以在这些参数中定义本地。...默认情况下,Laravel会假设你在用户模型中定义了 passport_id ,因为你试图创建与 passport 模型的关联。创建迁移文件时也请注意这一点!...你可以通过创建迁移文件在 Laravel 中创建此中间表。 远程关联 远程一对一 has one through 关联通过单个中间关联模型实现。...添加约束 可以在查询时向关系添加约束。看看下面的示例: <?

    5.5K31

    Laravel学习记录--Model

    如: hasOne(class,foreignkey,primarykey); class:关联模型的类名 foreignkey:关联模型的,如果不指定默认在这里默认为 muser_id...带条件约束的渴求式加载 有些时候我们需要为渴求是加载添加约束条件 以数组形式,如下例 public function show(){ $res = Article::with(['...) foreignPivotKey:当前模型在中间表的字段(当前模型类的) 如不指定,默认拼接规则为 表名_id,这里为stu_id relatedPivotKey:另一模型在中间表的字段(当前模型类的...morphs指定的名称一致 $table:中间表名称,默认为$name的复数形式 $foreignPivotKey:当前模型在中间表的,默认拼接规则为”当前表_id“ $relatedPivotKey...morphs指定的名称一致 $table:中间表名称,默认为$name的复数形式 $foreignPivotKey:关联模型在中间表的,默认拼接规则为”当前表_id“ $relatedPivotKey

    13.6K20

    深入mysql关联问题的详解--Java学习网

    今儿继续再看老师给推荐的深入浅出mysql数据库开发这本书,看到innodb数据库的关联问题时,遇到了一个问题,书上写的是可以对父表进行修改,从而同步到子表的上去,可是自己的实验却是没有能够。...然后自己又重新看了下书本,发现自己的sql语句中没有innodb的约束方式(cascade,set null,no action,restrict),感觉这就是自己出问题的地方。...150)-----我这里也建立索引了。...网上的说法是:字段类型和的索引 这里是重新建立一张表icity,结果可以了,总结可能是因为字段类型的问题,可是我的alter的问题还是没有解决呢: 代码如下: mysql> create...) ENGINE=InnoDB DEFAULT CHARSET=latin1 1 row in set (0.02 sec) 在大家(老师和网友)的帮助下终于搞定了,做法先drop掉表里的

    1K40

    两个非常棒的 Laravel 权限管理包推荐

    追本遡源 —— Laravel 官方权限功能支持在 5.1.11 版中引入之后就几乎没变过。...Laratrust 的问题是使用自己的 Laravel 命令替换默认 Laravel 命令,因此无法使用 Gates 或 @can 语法。...安装和使用 两个包的安装类似: 添加到 composer 安装; 在 config/app.php 中添加一个提供器和 facade (Bouncer); 发布和运行迁移; 在用户模型中引入指定的 trait...guard_name 具有默认值 web — 允许你使用多个 guard; 正如你看到的,有两个权限 中间表 — 角色和用户; 字段 model_type 具有默认值 App\User ,所以没有直接关联到...以下是 GitHub 上的链接: Laravel 5.4 admin panel based on Spatie Laravel-permission Laravel 5.4 admin panel based

    4.2K30

    【重学 MySQL】六十六、约束的使用

    【重学 MySQL】六十六、约束的使用 在MySQL中,约束是一种重要的数据库约束,用于确保表中的数据完整性。...约束的特点 从表的列,必须引用/参考主表的主键或唯一约束的列 为什么?...如果类型不一样,创建子表时,就会出现错误“ERROR 1005 (HY000): Can’t create table.database.tablename’(errno: 150)”。...约束约束等级 在MySQL中,约束约束等级决定了当主表中的记录被更新或删除时,子表中相应的记录将如何响应。...约束的作用 保证数据完整性:约束可防止在子表中插入指向不存在记录的键值。 强制数据关联:约束强制子表中的记录与主表中的记录相关联。

    7410

    Django中的数据迁移与数据库版本控制:概念、实践与优化策略

    在进行数据迁移时,需要确保每个模型都被迁移到正确的数据库中。5. 数据迁移约束当存在外约束时,数据迁移可能会变得复杂。在修改涉及的模型时,需要谨慎处理迁移顺序,以确保外约束的一致性。...数据迁移失败数据迁移过程中可能会出现各种错误,例如字段类型不匹配、约束冲突等。这些错误可能会导致迁移操作失败,影响系统的正常运行。...此外,可以通过合理的批处理和并发控制策略,减少数据库锁定的发生,并优化迁移操作以提高性能。4. 数据丢失和不一致不正确的数据迁移操作可能会导致数据丢失或者数据不一致的问题,给系统带来严重的风险。...社区活动和会议社区会组织各种形式的活动和会议,如研讨会、技术讲座等,为开发者提供学习和交流的机会。这些活动可以促进技术的交流和合作,推动数据迁移和数据库版本控制领域的发展。5....在接下来的部分,我们进一步讨论了数据迁移与数据库版本控制的进阶应用,包括自动化迁移、数据迁移的回滚、数据库备份与恢复、多数据库支持以及约束等。

    22310

    Oracle 数据库学习笔记 (二)

    二、表的相关操作 2.1 创建表 2.2 插入数据 insert 2.3 表创建(约束) 2.3.1 主键约束 2.3.2 非空约束 2.3.3 唯一约束 2.3.4 检查约束 2.3.5 约束 2.3.6...约束 在两张表中进行约束操作,这就要区别一下父表和子表的区别啦,父表的 ID 可以对 子表的 ID 具有约束租用 2.3.1 主键约束 关键字:primary key 主键约束可以确认每一行数据的唯一性...constraint xxx; -- 暂时禁用 alter table xxx drop constraint xxx; -- 永久删除 2.3.5 约束 创建表时设置约束 在修改表时添加约束...删除外约束 关键字: foreign key REFERENCES 主-约束是针对两张表的约束 有一张表 TA ,且表有主键,另外一张表中的某一列的数据完全取自于 TA,此时就 TB 表中该列为列...,添加主外约束来限制它 (TB 列上添加) 是不是有点绕口,我换个说法给大家 有两张表 A和B,A 表中的主键记为 AId,表B 的主键记为 BID,表 B 的 BID 加一个 ,引入 AId

    94721

    Go 数据存储篇(七):GORM 使用入门

    典型的 ORM 库比如 Java 中的 Hibernate、Ruby 中的 ActiveRecord、以及 Laravel 中的 Eloquent。...(类似 Laravel 框架的模型事件)。...}, &Comment{}) 通过 AutoMigrate 方法传入要迁移的模型类实例即可,GORM 会自动创建对应的数据表,表名规则是模型类名小写的复数形式。...分别对应数据表 posts 和 comments,并且在 Post 中通过如下方式定义了 Post 和 Comment 之间的一对多关联: Comments []Comment 这里我们没有用结构体标签指定关联...但是还是有一些字段设置了结构体标签,这是为了给该字段添加额外的数据表字段约束,比如索引、是否允许为空等: Author string `sql:"not null"` PostId int `sql:"

    3K20
    领券