亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

Laravel Eloquent復雜查詢從一張表中獲取最新數據

Laravel Eloquent復雜查詢從一張表中獲取最新數據

PHP
蝴蝶不菲 2023-08-11 16:45:51
我正在用 laravel 創建實時聊天系統。我想從數據庫獲取最新消息。我想從雄辯中得到這樣的查詢。$senderLastMessage = Message::where('sender_id',$user->id)->where('receiver_id',auth()->user()->id)->latest('created_at')->first(); $receiverLastMessage = Message::where('receiver_id',$user->id)->where('sender_id',auth()->user()->id)->latest('created_at')->first();現在我想要最新的消息,在這種情況下,最新的消息將從 auth->user 或其他用戶發送。我怎樣才能得到這個?如果我單獨得到這些。我將必須創建日期比較,例如檢查 senderLastMessage->created_at 的日期是否更大或receiverLastMessage->created_at 是否更大,或者如果它們相等,則獲取時間并檢查誰的時間更大,然后顯示該消息實例。我怎樣才能從雄辯中得到這個?
查看完整描述

1 回答

?
翻翻過去那場雪

TA貢獻2065條經驗 獲得超14個贊

只需在查詢中使用 OR 條件和一些括號


$lastMessage = Message::where( fuunction($query) use($user) {

    $query->where('sender_id',$user->id)

        ->orWhere('receiver_id', $user->id);

})->where( function($query) {

    $query->where('sender_id',auth()->id())

        ->orWhere('receiver_id', auth()->id());

})->latest('created_at')->first();


查看完整回答
反對 回復 2023-08-11
  • 1 回答
  • 0 關注
  • 165 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號