orm获取关联表里的属性值

2023-05-20,,

ORM——关系对象模型

laravel中的Eloquent ORM用于和数据表互动,其中每个数据库表会和一个对应的「模型」互动,想要了解请查看官方文档或自行百度。获取关联表里属性值代码如下:

    /**
* [getContactAttribute 获取卖家联系人]
*/
public function getContactAttribute()
{
return $this->hasOne('App\Http\Models\Supplier', 'SupplierId', 'SupplierId')->first()->contact;
}

  2、获取订单商品信息

    public function getProductInfoAttribute()
{
$info = $this->items()->get()->map(function ($item) {
$json = $item->format(['title', 'quantity']);//$json为数组
return implode('x', array_values($json));
})->toArray();//toArray()将object转换为数组
if (count($info) > 1) {
$info = implode(';', $info);
}else {
$info = $info[0];
}
return $info;
} /**
* [items 订单购买的商品]
* @return [type] [description]
*/
public function items()
{
return $this->hasMany('App\Http\Models\OrderItem', 'OrderId', 'OrderId');
}

  其中getProductInfoAttribute()方法用于获取订单商品的信息,最后效果是:商品1名字x数量;商品2名字x数量。eg:奥力根电链锯x1;金戈铁马台钻x3。

orm获取关联表里的属性值的相关教程结束。

《orm获取关联表里的属性值.doc》

下载本文的Word格式文档,以方便收藏与打印。