首页 > 解决方案 > Laravel Eloquent 仅从关系中选择列

问题描述

我有两个模型InvoiceTotal,并且MeterTariffInvoiceTotal 模型内部是一对多关系

public function meter_tariff() {
    return $this->belongsTo(MeterTariff::class);
}

with我正在使用anddistinct函数根据 invoice_id 查询所有唯一的meter_tariff 行。

$validatedData = $request->validate([
    'invoice_ids' => ['required', 'array'],
    'invoice_ids*' => ['exists:invoices, id']
]);

$meter_tariffs = InvoiceTotal::with('meter_tariff')
    ->whereIn('invoice_id', $validatedData['invoice_ids'])
    ->distinct('meter_tariff_id')
    ->get();

这工作正常。结果是一个基于meter_tariff_id 的具有唯一行的数组,但我从中获取了所有列InvoiceTotalMeterTariff关系。

我想限制选定的列id与关系之间nameMeterTariff关系。

我试过下面的代码。

选择:

$meter_tariffs = InvoiceTotal::with('meter_tariff')
    ->whereIn('invoice_id', $validatedData['invoice_ids'])
    ->distinct('meter_tariff_id')
    ->select('meter_tariff:id,name')
    ->get();

在with里面查询:

$meter_tariffs = InvoiceTotal::with(['meter_tariff' => function($query) {
        $query->select('id', 'name');
    }])
    ->whereIn('invoice_id', $validatedData['invoice_ids'])
    ->distinct('meter_tariff_id')
    ->get();

中的选择:

$meter_tariffs = InvoiceTotal::with('meter_tariff:id, name')
    ->whereIn('invoice_id', $validatedData['invoice_ids'])
    ->distinct('meter_tariff_id')
    ->get();

标签: phplaraveleloquent

解决方案


您可以使用 pluck 仅从 MeterTariff 关系中获取选定的列 - id 和 name。

$meter_tariffs = InvoiceTotal::with('meter_tariff')->whereIn('invoice_id', $validatedData['invoice_ids'])->distinct('meter_tariff_id')->get()->pluck('meter_tariff.id', 'meter_tariff.name')

推荐阅读