【问题标题】:Null value on updating column value during migration迁移期间更新列值的空值
【发布时间】:2023-03-31 11:25:01
【问题描述】:

我正在尝试将新列 slug 添加到现有表 devices 并为其分配随机唯一值。

以下是我的迁移脚本。

public function up()
    {

        Schema::table('devices', function(Blueprint $table){
            $table->string('slug');
        });

        $ids = DB::table('devices')->where('slug','')->pluck('id');

        //dd($ids);
        foreach ($ids as $id)
        {
            Device::whereId($id[0])->update(array('slug' => uniqid()));
        }


    }

迁移运行良好。但是 slug 字段在迁移后是一个空字符串。但它应该是一个唯一的字符串。

可能是什么问题?

【问题讨论】:

    标签: laravel laravel-5.2


    【解决方案1】:

    我认为是循环的问题,试试这个:

    foreach ($ids as $id)
    {
        Device::whereId($id)->update(array('slug' => uniqid()));
    }
    

    另外,你可以更简单

    public function up()
    {
        Schema::table('devices', function(Blueprint $table){
            $table->string('slug');
        });
    
        Device::update(['slug' => uniqid()]);
    }
    

    【讨论】:

      猜你喜欢
      • 2017-08-26
      • 2023-04-01
      • 2013-07-13
      • 2014-08-09
      • 1970-01-01
      • 2019-02-19
      • 2016-08-28
      • 2018-10-04
      • 2011-07-10
      相关资源
      最近更新 更多