douzachan4578 2018-06-07 22:24
浏览 582
已采纳

仅返回集合中的某些数据 - Laravel

I'm learning Laravel and have created a public endpoint where I want to output only certain information of some comments if a user is not authenticated from a GET request.

I have managed to filter out the comments based on whether or not they are approved. I now want to filter out the data that is returned. I have attached a screenshot of what is currently returned.

enter image description here

Ideally, I only want to return the id, name and the body in the json. How can I go about this? I tried the pluck() method which did not give the desired results. Any pointers would be greatly appreciated

public function index(Request $request)
{
    if (Auth::guard('api')->check()) {

        return Comment::all();

    } else {

        $comments = Comment::where('approved', 1)->get();

        return $comments->pluck('id','name','body');

    }
}
  • 写回答

3条回答 默认 最新

  • dsc80135 2018-06-07 22:37
    关注

    To select the particular columns, you can pass columns name to get as

    $comments = Comment::where('approved', 1) -> get(['id','name','body']); 
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?