繁体   English   中英

如何在Laravel Eloquent Jensseger Mongodb中使用急切加载的属性

[英]How To Use Get On Eager-loaded Attribute In Laravel Eloquent Jensseger Mongodb

我将Laravel与jenssegers Mongodb Eloquent一起使用。 当我尝试使用get([...])或distinct('...')时,它在结果中给出空值。 如何使用get([eager_loaded_attribute_here])只获得一个预先加载的给定属性?

例:

Message::with(['sender','receiver'])
    ->where('sender_id', '=', Auth::user()->_id)
    ->orWhere('receiver_id', '=', Auth::user()->_id)
    ->orderBy($request->orderBy, $request->orderByDirection)
    ->skip(intval($request->offset))
    ->take(intval($request->limit))
    ->get()

给出:

[
    {
        "_id": "5abc2ba193782d24996aefda",
        "receiver_id": "5abc28bd93782d235238c162",
        "text": "Hello!",
        "sender_id": "5abc2b8b93782d24996aefd8",
        "updated_at": "2018-03-28 23:56:17",
        "created_at": "2018-03-28 23:56:17",
        "sender": {
            "_id": "5abc2b8b93782d24996aefd8",
            "name": "Test 5",
            "updated_at": "2018-03-29 00:05:48",
            "created_at": "2018-03-28 23:55:55"
        },
        "receiver": {
            "_id": "5abc28bd93782d235238c162",
            "name": "Test 1",
            "updated_at": "2018-04-20 13:26:00",
            "created_at": "2018-03-28 23:43:57"
        }
    },
...
]

但是使用get:

Message::with(['sender','receiver'])
    ->where('sender_id', '=', Auth::user()->_id)
    ->orWhere('receiver_id', '=', Auth::user()->_id)
    ->orderBy($request->orderBy, $request->orderByDirection)
    ->skip(intval($request->offset))
    ->take(intval($request->limit))
    ->get(['sender'])

给出:

[
    {
        "_id": "5abc2ba193782d24996aefda",
        "sender": null,
        "receiver": null
    },
...
]

同样,当使用distinct:

$correspondants=Message::with(['sender','receiver'])
    ->distinct('sender_id')
    ->where('sender_id', '=', Auth::user()->_id)
    ->orWhere('receiver_id', '=', Auth::user()->_id)
    ->orderBy($request->orderBy, $request->orderByDirection)
    ->skip(intval($request->offset))
    ->take(intval($request->limit))
    ->get()
    ->toArray();

给出:

[
    {
        "0": "5abc2b8b93782d24996aefd8",
        "sender": null,
        "receiver": null
    }
]

用这个:

->get()->pluck('sender');

如果您需要查询生成器:

$senderIds = Message::distinct('sender_id')
    ->where('sender_id', '=', Auth::user()->_id)
    [...]
    ->pluck('sender_id');
$senders = Sender::whereKey($senderIds)
    [...]
    ->get();

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM