Я создаю платформу, на которой тренер сможет добавлять курсы в свой профиль. Но прежде чем он добавит курс, необходимо принять заявление, которое необходимо сделать.
Итак, ранее я разбил свою базу данных на три части:
users | trainer | course
После небольшого исследования я обнаружил, что мне придется нормализовать базу данных, но у меня возникли проблемы с ее настройкой.
Теперь у меня есть trainer
таблица trainer_experience
таблица и trainer_achievements
таблица. В таблице опыта тренера я должен сохранить данные о положении, в котором они были, и название компании.
Мой тренерский стол такой:
<?php
use Illuminate\Support\Facades\Schema;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;
class CreateTrainersTable extends Migration
{
/**
* Run the migrations.
*
* @return void
*/
public function up()
{
Schema::create('trainers', function (Blueprint $table) {
$table->bigIncrements('id');
$table->unsignedBigInteger('user_id');
$table->date('date_of_birth');
$table->integer('mobile_number');
$table->longText('address');
$table->string('id_proof');
$table->string('id_registration_number');
$table->string('high_school_name');
$table->string('graduation_college_name');
$table->string('graduation_course_name');
$table->string('post_graduation_college_name');
$table->string('post_graduation_course_name');
$table->string('phd_field_of_study');
$table->string('total_duration_of_training');
$table->integer('no_of_people_trained');
$table->boolean('paid_training');
$table->string('training_category');
$table->string('course_material_ready');
$table->string('youtube_link')->nullable();
$table->string('twitter_link')->nullable();
$table->string('instagram_link')->nullable();
$table->string('facebook_link')->nullable();
$table->string('linkedin_link')->nullable();
$table->string('blog_link')->nullable();
$table->string('website_link')->nullable();
$table->string('meetup_group_link')->nullable();
$table->timestamps();
$table->index('user_id');
});
}
/**
* Reverse the migrations.
*
* @return void
*/
public function down()
{
Schema::dropIfExists('trainers');
}
}
Как мне сохранить данные, чтобы я мог хотя бы получить их в порядке их ввода? Нужно ли составлять две разные таблицы? Какой лучший вариант у меня есть?