dpepbjp126917 2019-06-10 14:24
浏览 151
已采纳

通过laravel迁移添加'on update'和'on delete'外键约束

I am making my table like this...

    Schema::create('matched_merchants', function (Blueprint $table)
    {
        $table->increments('id')->unsigned();
        $table->integer('merchant_id')->unsigned();
        $table->integer('offer_id')->unsigned();
        $table->foreign('merchant_id')->references('id')->on('merchants')->onUpdate('cascade')->onDelete('restrict');
        $table->foreign('offer_id')->references('id')->on('offers')->onUpdate('cascade')->onDelete('restrict');
    });

Im adding 2 foreign keys both have onUpdate and onDelete constraints but only the update constraint gets added.

If i delete the onUpdate, it will correctly add the onDelete constraint.

I cannot add them separately because i get the error of duplicate key.

I could add them manually with a raw sql statement but if theres a right way to do it id rather do that.

  • 写回答

1条回答 默认 最新

  • douxiaochun4964 2019-06-10 14:49
    关注

    For some reason, if you set the columns as nullable(), Laravel sets the foreign keys correctly.

    That said, I can see that causing other problems, so I recommend doing the raw SQL statement.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
  • ¥50 成都蓉城足球俱乐部小程序抢票
  • ¥15 yolov7训练自己的数据集
  • ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)
  • ¥15 电力市场出清matlab yalmip kkt 双层优化问题
  • ¥30 ros小车路径规划实现不了,如何解决?(操作系统-ubuntu)