Может быть много подходов.
Я предложу 2 способа, которыми я бы лично использовал:
1) Создайте выделенные красноречивые модели по одному для каждого случая.
Например:
if($answer->employeeType === 1){
EmployeeOne::create($answer);
}
И ваша красноречивая модель может выглядеть следующим образом:
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Model;
use DB;
class EmployeeOne extends Model
{
protected $table = 'type_one_table';
/**
* The attributes that are mass assignable.
*
* @var array
*/
protected $fillable = [
// your db field names
];
/**
* The attributes that should be hidden for arrays.
*
* @var array
*/
protected $hidden = [
];
public $timestamps = false;
}
Убедитесь, что ключи массива массива, который вы передаете в функцию создания, должны соответствовать вашей БДполя.Я только что дал вам пример первого if
, чтобы вы могли взять его отсюда.
2) Другой подход заключается в создании модели, которая принимаетв качестве параметра имя таблицы.Таким образом, основываясь на вашем if
, вы передадите имя таблицы, которую хотите вставить, и данные, которые нужно вставить.
if($answer->employeeType === 1){
$this->myModel->insertData($answer,'type_one_table');
}
И в вашей модели у вас будет что-то вроде:
public function insertData($answer,$table){
$query = DB::table($table)->insertGetId($answer); // returns the id of the new record
return $query;
}
Так что в каждом операторе if-else
вы просто меняете имя таблицы, передавая ее функции модели, и этоЭто.