我有一個用于存儲特定藝術家的記錄數據的表單頁面。大多數數據屬于記錄表,但有些數據應該存儲在相關表中。我現在主要關心的是流派表。在流派表中,我有 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,您可以在此處閱讀有關它們的更多信息。

牛魔王的故事
TA貢獻1830條經驗 獲得超3個贊
請試試這個
....
$genre->save();
$genre->recordings()->create([
"recording_date"=>$request->input('recording_date'),
"release_date"=>$request->input('release_date'),
"lyrics"=>$request->input('lyrics')
]);
- 2 回答
- 0 關注
- 167 瀏覽
添加回答
舉報
0/150
提交
取消