Laravel доступ к значениям из объекта в объекте - PullRequest
0 голосов
/ 15 марта 2020

В одной из функций контроллера

$readings = Reading::orderBy('reading_date_time', 'DESC')->get();
dd($readings);

Это дает

Illuminate\Database\Eloquent\Collection {#1883
  #items: array:160 [
    0 => App\Reading {#1722
      #fillable: array:6 [ …6]
      #connection: "mysql"
      #table: "readings"
      #primaryKey: "id"
      #keyType: "int"
      +incrementing: true
      #with: []
      #withCount: []
      #perPage: 15
      +exists: true
      +wasRecentlyCreated: false
      #attributes: array:8 [ …8]
      #original: array:8 [ …8]
      #changes: []
      #casts: []
      #dates: []
      #dateFormat: null
      #appends: []
      #dispatchesEvents: []
      #observables: []
      #relations: []
      #touches: []
      +timestamps: true
      #hidden: []
      #visible: []
      #guarded: array:1 [ …1]
    }...

Как получить доступ к фактическим значениям таблицы показаний. И использовать их для таких операций, как array_column ().

Ответы [ 2 ]

0 голосов
/ 15 марта 2020

Вы можете использовать toArray() helper

Метод toArray преобразует коллекцию в простой массив PHP. Если значениями коллекции являются модели Eloquent, модели также будут преобразованы в массивы

$readings = Reading::orderBy('reading_date_time', 'DESC')->get()->toArray();

/*
    [
        ['column1' => 'value1', 'column2' => 'value2', ...],
        ['column1' => 'value1', 'column2' => 'value2', ...],
        ['column1' => 'value1', 'column2' => 'value2', ...],
        ...
    ]
*/

. Затем вы можете использовать array_column() для $readings , массив

$pluckedValues = array_column($readings, 'chosen_column');

print_r($pluckedValues);
0 голосов
/ 15 марта 2020

Эта функция уже дает вам результат, и результат равен collection .

Вы можете вызвать атрибут по одному объекту в коллекции:

$readings->first()->reading_date_time;

и вы можете использовать method-pluck , чтобы получить значения атрибутов из коллекции, как и array_column:

$readings->pluck('reading_date_time');

Если вы используете array_column, вы можете использовать метод -toArray чтобы изменить коллекцию на массив:

array_column($readings->toArray(), 'reading_date_time')
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...