Laravel 4 Um-Para-Muitos com o local onde
Pergunta
Eu tenho dois da tabela de PRODUTOS e ESTOQUE.
Products
--------
id
name
Stock
-------
id
products_id
organization
price
o meu código:
class ProductsModel extends Eloquent {
protected $table = 'products';
public function stock(){
return $this->hasMany('StockModel', 'products_id');
}
class StockModel extends Eloquent {
protected $table = 'stock';
}
Se eu uso:
$data['products'] = ProductsModel::where('id', $id)->stock()->where('organization', 1)->get();
Ou
$data['products'] = ProductsModel::where('id', $id)->stock->where('organization', 1)->get();
receber o erro:
Laravel throw error: Undefined property: Illuminate\Database\Eloquent\Collection::$stock
Solução
Como você está passando um id de produto, eu suponho que você quer apenas uma instância do produto.Você pode tentar isso
$product = ProductsModel::find($id);
$stocks = $product->stock;
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow