亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何使用 Laravel 使用 1 個表單插入多個表

如何使用 Laravel 使用 1 個表單插入多個表

PHP
胡子哥哥 2022-07-09 18:25:36
我有一個用于存儲特定藝術家的記錄數據的表單頁面。大多數數據屬于記錄表,但有些數據應該存儲在相關表中。我現在主要關心的是流派表。在流派表中,我有 Name 列。我對表單提交后的理想流程的想法是:檢查流派名稱是否已存在如果不是:存儲名稱并將其 id 用作 fk如果是:獲取流派 id 并將其用作 fk我正在處理的是 Recording 控制器中的 store 方法。目前我正在使用錄音表中的 $recording_date、$release_date 和 $lyrics。免責聲明:我不會向您展示我嘗試過的大部分內容,因為無法向您展示我嘗試過的所有方式,而且它也是無用的,因為問題不在于我不明白為什么它不起作用。我根本找不到任何方法來正確使用包含相同約束和一對多關系的 Eloquent。大多數人會建議我以單獨的形式進行。另外我知道我現在沒有處理驗證。無論如何,我可以找到適用于我的類似案例信息的任何想法或建議都會有所幫助。<!--Form snippet--><div class="form-group">    <div class="input-group">        <input type="text" name="genre" class="form-control" placeholder="Genre" autocomplete="off">    </div></div>以下是我嘗試過的最新代碼。它不起作用的明顯原因是它不處理外鍵。//Recording controllerpublic function store(Request $request)    {        $genre = new Genre();        $genre->name = $request->input('genre');        $recording = new Recording();        $recording->genre_id = $genre->id;        $recording->recording_date = $request->input('recording_date');        $recording->release_date = $request->input('release_date');        $recording->lyrics = $request->input('lyrics');        $recording->save();    }//Recording tablepublic function up()    public function up()    {        Schema::create('recordings', function (Blueprint $table) {            $table->bigIncrements('id');            $table->unsignedInteger('genre_id')->nullable();            $table->string('recording_date')->nullable();            $table->string('release_date')->nullable();            $table->text('lyrics')->nullable();            $table->timestamps();        });    }//Genres table public function up()    {        Schema::create('genres', function (Blueprint $table) {            $table->bigIncrements('id');            $table->string('name')->unique()->nullable();            $table->string('subgenre')->nullable();            $table->timestamps();        });    }//Recording modelclass Recording extends Model{    protected $guarded = [];    public function genre() {        return $this->belongsTo(Genre::class);    }}
查看完整描述

2 回答

?
一只名叫tom的貓

TA貢獻1906條經驗 獲得超3個贊

為了保存到關系表中,您必須執行以下操作:

$recording->genre()->create('your data array here')

你可以在這里閱讀更多關于它的信息。

現在,如果您想檢查 $recording 是否具有類型,您可以首先使用 exists() ,例如:

$recording->genre()->exists()

另一種選擇是使用方法 firstOrCreate、firstOrNew,您可以在此處閱讀有關它們的更多信息。


查看完整回答
反對 回復 2022-07-09
?
牛魔王的故事

TA貢獻1830條經驗 獲得超3個贊

請試試這個


....


$genre->save();


$genre->recordings()->create([

  "recording_date"=>$request->input('recording_date'),

  "release_date"=>$request->input('release_date'),

  "lyrics"=>$request->input('lyrics')

]);


查看完整回答
反對 回復 2022-07-09
  • 2 回答
  • 0 關注
  • 167 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號