首页 > 解决方案 > 使用 Laravel 为一对多类别结构创建数据记录

问题描述

我是新来的。使用 Laravel,我想保存具有多项选择功能的数据。但是,我创建的模型文件中的方法没有出现。我是幼虫的新手,我该如何解决?我无法运行多项选择功能。

控制器中的方法

public function saveForm()
{
    $movi_name = $req->input('movi_name');
    $release_date = $req->input('release_date');

    $data = array(
        'movi_name'    => $movi_name,
        'release_date' => $release_date
    );

    $categories = request(categories);

    $entry = Movie::insert($data) /*Model File and Save Data*/

    $entry->categories()->attach($categories);
}

我的模型文件中的方法

protected $table = 'film';

public function categories()
{
    return $this->belongsToMany('App\Models\Kategori', 'category_movie');   
}

应该是选择的电影必须包含在类别中..但是

在布尔值上调用成员函数 categories()

对不起英语不好

标签: phplaravel

解决方案


如评论中所述,您应该使用create()而不是insert().

Usinginsert()将简单地返回truefalse取决于查询是否成功。

Usingcreate()将返回一个Movie模型实例,该实例将包含该categories()方法:

$entry = Movie::create($data); //<--This is where insert() is replaced with create()

$entry->categories()->attach($categories);

您需要确保movi_name并且release_date位于模型的 $fillable数组中Movie

protected $fillable = ['movi_name', 'release_date'];

推荐阅读