首页 > 解决方案 > Eloquent 错误地将多个模型保存到数据库

问题描述

我有一个控制器,它创建一个新模型然后将它传递给视图

public function fill_site_form($id, $step_id, $form_id){
    $form = new FormEntry();
    $form->site_id = $id;
    $form->form_id = $form_id;
    $form->step_id = $step_id;
    $form->entry_json = Form::find($form_id)->form_json;
    $form->save();
    return view('sites.fill_site_form', ['form' => $form]);
}

我需要它只在数据库中创建一条记录,但每次我去那条路线时它都会创建两条记录。

我删除了 ->save,然后没有记录插入到数据库中。

有什么建议么?

编辑:

  1. $form->save 上的 DB 条目图像: SCREENSHOT IMAGE LINK

  2. 数据库架构:

    Schema::create('form_entries', function (Blueprint $table) {
        $table->increments('id');
        $table->integer('site_id');
        $table->integer('form_id');
        $table->integer('step_id');
        $table->text('entry_json', 600000);
        $table->timestamps();
    });
    
  3. 从 sites.fill_site_form 视图接收 ajax 的代码

    public function update_site_ajax($id, Request $request){
        $entry = FormEntry::find($id);
        $entry->entry_json = json_encode($request->form_json);
        $entry->save();
        return $request->all();
    }
    
  4. 前端AJAX代码:

        $('#submit_button').click((e)=>{
            $.ajax({
                type:'PATCH',
                url:'/site/' + document.getElementById('form_id').value,
                data:  {'form_json' : renderer.userData},
    
                success:function(data){
                    $.notify("Form successfully Updated!",
                        {
                            position:"top center",
                            className: 'success'
                        }
                    );
                    console.log('Response: ', data)
                }
    
            });
        });
    

标签: phplaraveleloquentmodel

解决方案


我无法让它与 Model::create 或 Model->save 一起使用,所以我求助于看起来更稳定的 Model::firstOrCreate,仍然想知道为什么只在该模型上创建两个条目


推荐阅读