Home > Back-end >  Call to a member function find() on array
Call to a member function find() on array

Time:11-16

 "message": "Call to a member function find() on array",
    "exception": "Symfony\\Component\\Debug\\Exception\\FatalThrowableError",

How do I get the id parameter from the array below: When i pass the parameter 1 i want to fetch only first element when id is 2 I fetch item 2 of array

  public function payments($id){
        $data = [
            ['id' => 1, 'amount' => '22000', 'name' => 'ken'],
            ['id' => 2, 'amount' => '24000', 'name' => 'ken'],
            ['id' => 3, 'amount' => '26000', 'name' => 'ken'],
            ['id' => 4, 'amount' => '2000', 'name' => 'tom'],
        ];

        return $data->find($id);
    }

CodePudding user response:

Since we're using a multi-dimensional array, we can use array_search with array_column.

$data = [
    ['id' => 1, 'amount' => '22000', 'name' => 'ken'],
    ['id' => 2, 'amount' => '24000', 'name' => 'ken'],
    ['id' => 3, 'amount' => '26000', 'name' => 'ken'],
    ['id' => 4, 'amount' => '2000', 'name' => 'tom'],
];
        
$key = array_search($id, array_column($data, 'id'));
echo var_dump($data[$key]);

CodePudding user response:

If you want a "Laravel" alternative solution using collection

public function payments($id){
    $data = [
        ['id' => 1, 'amount' => '22000', 'name' => 'ken'],
        ['id' => 2, 'amount' => '24000', 'name' => 'ken'],
        ['id' => 3, 'amount' => '26000', 'name' => 'ken'],
        ['id' => 4, 'amount' => '2000', 'name' => 'tom'],
    ];
    $data = collect($data);
    return $data->where('id', $id)->first();
}
  • Related