TL;DR: Need latest message from each sender.
In my Laravel application I have two tables:
Users:
Messages:
You can try this one
Messages::where('recipient_id',**{USER_ID}**) ->group_by('sender_id') ->order_by('id','desc') ->get();