Как сделать реляционные базы данных Laravel ORM


Как сделать реляционные базы данных Laravel ORM

04.11.2015 05:47:00 Просмотров 44 Источник

У меня есть таблица категорий, которая содержит :

Schema::create('categories',function($table){
    $table->increments('id');
    $table->string('name',25);
    $table->timestamps();
});

и таблица продуктов :

Schema::create('products',function($table){
    $table->increments('id');
    $table->integer('category_id')->unsigned();
    $table->foreign('category_id')->references('id')->on('categories');
    $table->string('name',25);
    $table->text('description');
    $table->timestamps();
});

и product_image :

Schema::create('images',function($table){
    $table->increments('id');
    $table->integer('product_id')->unsigned();
    $table->foreign('product_id')->references('id')->on('products');
    $table->string('src',100);
    $table->timestamps();
});

А мои модели :

Категория:

class Category extends Eloquent{
    public function Test() {
        return $this->hasMany('Product');
    }
}

Продукт:

class Product extends Eloquent
{
    public function category(){
        return $this->belongsTo('Category');
    }

    public function images() {
        return $this->hasMany('Images');
    }
}

Теперь я хочу показать каждую категорию в div с первой фотографией продукта.

Route::get('test',function(){
    $category = Category::all();
    foreach($category as $cat){
        dd($cat->Test->first()->images->first()->src);
    }
});

но я получаю эту ошибку :

Trying to get property of non-object

Может ли кто-нибудь помочь мне, почему я получаю эту ошибку ?

У вопроса есть решение - Посмотреть?

Ответы - Как сделать реляционные базы данных Laravel ORM / How to do Laravel ORM Relational Databases

Является ответом!
Milan Maharjan

04.11.2015 05:57:19

вы пропустили () при вызове realtion.

dd($cat->test()->first()->image()->first()->src);
Помочь в развитии проекта:
Закрыть X