Ila*_*kel 5 php laravel eloquent laravel-5 laravel-eloquent
我正在为我的应用程序开发 API。
我正在尝试从数据库中提取项目并在 JSON 对象中返回它们,我的项目表如下所示:
Items
-id
-name
-description
-price
-currency_id
-company_id
Run Code Online (Sandbox Code Playgroud)
这就是我获取物品的方式:
$rows = Company::where('guid',$guid)
->first()
->items()
->orderBy('name', $sort_order);
Run Code Online (Sandbox Code Playgroud)
我想用包含货币表所有列的货币对象替换货币 ID
所以我的结果会是这样的:
[
{
'id':'1',
'name':'name',
'description': 'example',
'price':'100',
'currency':{
'id':'1',
'name':'usd',
'symbol': '$'
}
}
]
Run Code Online (Sandbox Code Playgroud)
更新:这是我的货币表:
id
name
symbol
code
Run Code Online (Sandbox Code Playgroud)
编辑2:用户的问题比这更复杂,因为查询中存在分页和搜索集成。帮助https://pastebin.com/ppRH3eyx
编辑:我已经测试了代码。所以在这里。
公司模式
public function items()
{
return $this->hasMany(Item::class);
}
Run Code Online (Sandbox Code Playgroud)
在项目模型中
public function currency()
{
return $this->belongsTo(Currency::class);
}
Run Code Online (Sandbox Code Playgroud)
控制器逻辑
$items = Company::with(['items' => function($query) use ($sort_order) {
$query->with('currency')->orderBy('name', $sort_order);
}])
->where('guid', $guid)
->first()
->items;
Run Code Online (Sandbox Code Playgroud)
测试数据结果
[
{
"id": 2,
"name": "Toy",
"description": "Random text 2",
"price": 150,
"company_id": 1,
"currency_id": 1,
"currency": {
"id": 1,
"name": "usd",
"symbol": "$",
"code": "USD"
}
},
{
"id": 1,
"name": "Phone",
"description": "Random text",
"price": 100,
"company_id": 1,
"currency_id": 1,
"currency": {
"id": 1,
"name": "usd",
"symbol": "$",
"code": "USD"
}
}
]
Run Code Online (Sandbox Code Playgroud)
尝试这个。
$rows = Company::with('items.currency')
->where('guid', $guid)
->first()
->items()
->orderBy('name', $sort_order);
Run Code Online (Sandbox Code Playgroud)