質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

88.05%

Laravel5.5 編集ページに反映できない

受付中

回答 0

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 471

score 19

以下はレシピコントローラーのeditとupdateの部分

 public function edit($id)
    {
        $recipe = Recipe::find($id);
        $ingredient = Recipe::find($id)->ingredient;
        $how_to = Recipe::find($id)->how_to;

        return view('recipes.edit',[
            'recipe' => $recipe,
            'ingredients' => $ingredient,
            'how_tos' => $how_to,
        ]);
    }
// putまたはpatchでrecipes/idにアクセスされた場合の「更新処理」
    public function update(Request $request, $id)
    {
        $recipe = Recipe::find($id);
        $ingredient = Recipe::find($id)->ingredient;
        $how_to = Recipe::find($id)->how_to;
        $recipe->name = $recipe->name;
        $recipe->content = $recipe->content;
        $ingredient->ingredient = $ingredient->ingredient;
        $ingredient->quantity = $ingredient->quantity;
        $how_to->how_to_make = $how_to->how_to_make;
        $recipe->save();

        return back();
    }


以下は編集ページ

<div class="container">
        <div class="row">
            <div class="col-3">
            {!! Form::model($recipe, ['route' => ['recipes.update', $recipe->id], 'method' => 'put']) !!}
                <div class="form-group">
                    {!! Form::label('name', 'レシピ名') !!}
                    {!! Form::text('name', null, ['class'=> 'form-control']) !!}
                </div>
            </div>
            <div class="col-6 offset-3">
                <div class="form-group">
                    {!! Form::label('content', 'ひとこと') !!}
                    {!! Form::text('content', null, ['class'=> 'form-control']) !!}
                </div>
            </div>
        </div>
    </div>
<div class="container">
        <div class="row">
            <div class="col-4">
                <img src="https://placehold.jp/200x200.png"></img>
            </div>
            <div class="col-8">
                <h3>材料(2人分)</h3>
                    <div class="row">
                        <div class="col-md-8">
                            <div class="form-group">
                                {!! Form::label('ingredient', '材料・調味料名') !!}
                                <?php
                                    for($i = 0; $i <=7; $i++){
                                ?>
                                {!! Form::text("ingredients[$i][ingredient]", null, ['class'=> 'form-control']) !!}
                                <?php } ?>
                            </div>
                        </div>
                        <div class="col-md-4">
                            <div class="form-group">
                                {!! Form::label('quantity', '分量') !!}
                                <?php
                                    for($i = 0; $i <=7; $i++){
                                ?>
                                {!! Form::text("ingredients[$i][quantity]", null, ['class'=> 'form-control']) !!}
                                <?php } ?>
                            </div>
                        </div>
                    </div>
            </div>
        </div>
    </div>
<div class="container">
        <h3>作り方</h3>
        <div class="row">
            <?php
                for($i = 0; $i <=7; $i++){
            ?>
            <div class="col-md-3">
                {!! Form::label('how_to_make', $i+1) !!}
                {!! Form::textarea("how_to[$i][how_to_make]", null, ['class'=> 'form-control']) !!}
            </div>
            <?php } ?>
        </div>
    </div>
    <div class="container">
        <div class="row">
            <div class="col-6">
                {!! Form::submit('更新', ['class' => 'btn btn-dark']) !!}
            {!! Form::close() !!}
            </div>
        </div>
    </div>
</div>


以下は3つのデーターベース

namespace App;

use Illuminate\Database\Eloquent\Model;

class Recipe extends Model
{
    protected $fillable = ['user_id', 'name', 'content', 'photo_url'];

    public function user()
    {
        return $this->belongsTo(User::class);
    }

    public function ingredient()
    {
        return $this->hasMany(Ingredient::class);
    }

    public function how_to()
    {
        return $this->hasMany(HowTo::class);
    }
}
namespace App;

use Illuminate\Database\Eloquent\Model;

class Ingredient extends Model
{
    protected $fillable = ['recipe_id', 'ingredient', 'quantity'];

    public function recipe()
    {
        return $this->belongsTo(Recipe::class);
    }
}
namespace App;

use Illuminate\Database\Eloquent\Model;

class HowTo extends Model
{
    protected $fillable = ['recipe_id', 'how_to_make'];

    public function recipe()
    {
        return $this->belongsTo(Recipe::class);
    }
}


レシピ名・ひとこと・作り方は編集画面に反映されていますが、材料と分量の部分が反映されません。
1対多の関係で配列で格納したDBからうまく引っ張ってこれていないのでしょうか?
また、更新ボタンを押してもエラーが発生し、うまく更新されません。
更新の際のエラーはこちらです。

SQLSTATE[42S22]: Column not found: 1054 Unknown column 'ingredient' in 'field list' (SQL: update `recipes` set `updated_at` = 2018-12-29 13:42:36, `ingredient` = [], `quantity` = , `how_to_make` = where `id` = 27)


どこがおかしいのでしょうか?

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正の依頼

  • m.ts10806

    2018/12/29 13:45

    追記は質問本文にお願いします
    ただ、エラーに原因ちゃんと書いてありますね

    キャンセル

  • Ryosukevvvv

    2018/12/29 14:10

    $recipeと $ingredient 、$how_toの3つはdd()関数で確認したところデータを引き取れました。
    その後に問題がありそうです。

    キャンセル

  • asahina1979

    2018/12/31 13:38

    いや・・・エラーメッセージ読もうよ

    キャンセル

まだ回答がついていません

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 88.05%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る