Property ○○ does not exist on this collection instance の解決法

Laravelデータベース
スポンサーリンク

Laravelでこのエラーが出た原因は、コレクションを単体として扱ったから。

foreachなどを使って、要素をひとつずつ取り出して処理すると、解決できます。

たとえば、このようなコードをコントローラーに書いたとします。

        $question=Question::where(‘test_id’, $testId)->get();

コードの意味

Questionモデルのデータベースの中で、text_idカラムが、$testIDになっているデータを全て取得。
これを、変数$questionの中に格納してね。
このあと$questionを使う際、【単体】として処理すると、このエラーになります。
Property [○○] does not exist on this collection instance.
なぜなら、$questionは単数形ですが、getメソッドを使っているので、複数のデータを取得してくる可能性があります。
たとえ実際はひとつだけのデータしか入っていなくても、Laravel側では、そう判断します。
エラーを解決するには、foreachなどを使って、ひとつずつの要素に分けて処理してみてください。
状況によっては、下記のようにget()ではなくfirst()を使う手もあり。
first()であれば、取得してくる要素はひとつだけになります。
エラー解決を願っております。
ひとことメモ

エラーを避けるため、変数名をつけるときは、複数になる可能性があるものは複数形で名前をつけておきましょー
Laravelデータベース Laravel・PHP豆知識・トラブル対策

【無料プレゼント】

「LaravelでWebアプリをいちから作れるようになりたい!」

そんなLaravel初心者のあなたへ【Laravelの教科書】基礎編プレゼント中!
会員制フォーラムサイトを学習しながら作れます。

詳細はこちらをクリック

【個別サポート実施中】

「本ブログに記載の方法を試してみたけれど、うまくいかない」「コードを見てほしい」という方のために、有償でメールサポートいたします。以下のボタンをクリックして相談フォームにアクセスして下さい。

詳しく見る

Twitter始めました。
スポンサーリンク
40代からプログラミング!

コメント

タイトルとURLをコピーしました