猿问

有没有办法从 Laravel 中急切加载的表中选择字段?

所以我在下面定义了几个关系表


父数据库:


public function backorderQuantities(){

        return $this->hasMany(BackorderQuantity::class, 'ITEMNMBR', 'ITEMNMBR')->where('SOPTYPE', 5);

    }

关系数据库:


 public function item(){

        return $this->belongsTo(Item::class, 'ITEMNMBR', 'ITEMNMBR');

    }

我这样称呼这种关系:


Item::has('backorderQuantities')

            ->select('ITEMNMBR',

                Item::raw("SUM(QTYONHND) as qty"),

                Item::raw("SUM(QTYONORD) as ordered"),

                Item::raw("SUM( ( CASE WHEN LOCNCODE LIKE 'IT-%' THEN QTYONHND END ) ) as transit"), 

            )

            ->where('PRIMVNDR', Auth::user()->vendor_id)

            ->groupBy('ITEMNMBR')

            ->orderBy($group['field'], $group['sort'])

        );

这工作正常,但我还需要从 backorderQuantities 中选择字段,以便我可以按所述字段进行排序。换句话说,我想做这样的事情:


 Item::has('backorderQuantities')

            ->select('ITEMNMBR',

                Item::raw("SUM(QTYONHND) as qty"),

                Item::raw("SUM(QTYONORD) as ordered"),

                Item::raw("SUM( ( CASE WHEN LOCNCODE LIKE 'IT-%' THEN QTYONHND END ) ) as transit"),

                'backorderQuantities->QUANTITY'

            )

            ->where('PRIMVNDR', Auth::user()->vendor_id)

            ->groupBy('ITEMNMBR')

            ->orderBy('backorderQuantities->QUANTITY', $group['sort'])

但我遇到了这样的错误:


SQLSTATE[42S22]:[Microsoft][SQL Server 的 ODBC 驱动程序 17][SQL Server]列名称“backorderQuantities”无效。(SQL: select count(*) 作为聚合 from (select [ITEMNMBR], SUM(QTYONHND) 作为数量, SUM(QTYONORD) 作为订购, SUM( ( CASE WHEN LOCNCODE LIKE 'IT-%' THEN QTYONHND END ) ) 作为中转, json_value([backorderQuantities], '$."QUANTITY"') from [IV00102] 存在(从 [SOP10200] 选择 *,其中 [IV00102].[ITEMNMBR] = [SOP10200].[ITEMNMBR] 且 [SOPTYPE] = 5 ) 和 [PRIMVNDR] = YHI 按 [ITEMNMBR]) 分组为 [aggregate_table])


可能是因为当时该表仍在急切加载。有什么办法可以做到这一点吗?任何帮助将非常感激!


德玛西亚99
浏览 76回答 2
2回答

米脂

您将需要使用join而不是预先加载。

倚天杖

您可以使用with选择 eger 加载列: Item::with('backorderQuantities:QUANTITY,...');不要忘记将backorderQuantities表的 forigen 键传递给选定的列编辑 :要按子列排序,您应该使用 join 语句: Item::select('items.*')->leftJoin('items.ITEMNMBR','=','backorderQuantities.ITEMNMBR')->groupBy('backorderQuantities.ITEMNMBR')->orderBy('backorderQuantities.backorderQuantities')
随时随地看视频慕课网APP
我要回答