Должен ли я сделать несколько моделей для моей миграции с разными таблицами

У меня есть миграция с несколькими таблицами: Status, Status_project, Status_task. Могу ли я вызвать их все только с помощью моей модели состояния, созданной с помощью команды миграции?

php artisan make:model Status -m

Я читал в нескольких местах, что мне нужно сделать модель для каждой таблицы, но нет ли другого пути? Кроме DB::table('статусы'). Из-за моих отношений я не предпочитаю несколько моделей

Пример:

  Schema::create('statuses', function (Blueprint $table) {
        $table->bigIncrements('id');
        $table->string('name')->unique();
        $table->string('display_name')->nullable();
        $table->string('description')->nullable();
        $table->timestamps();
    });

    Schema::create('status_task', function (Blueprint $table) {
        $table->bigIncrements('id');
        $table->string('user_id')->nullable();
        $table->unsignedBigInteger('task_id');
        $table->unsignedBigInteger('status_id');

        $table->foreign('user_id')->references('id')->on('users')
            ->onUpdate('cascade')->onDelete('cascade');
        $table->foreign('task_id')->references('id')->on('ongoing_tasks')
            ->onUpdate('cascade')->onDelete('cascade');
        $table->foreign('status_id')->references('id')->on('statuses')
            ->onUpdate('cascade')->onDelete('cascade');

    });

    Schema::create('status_project', function (Blueprint $table) {
        $table->bigIncrements('id');
        $table->string('user_id')->nullable();
        $table->string('project_id');
        $table->unsignedBigInteger('status_id');

        $table->foreign('user_id')->references('id')->on('users')
            ->onUpdate('cascade')->onDelete('cascade');
        $table->foreign('project_id')->references('id')->on('ongoing_projects')
            ->onUpdate('cascade')->onDelete('cascade');
        $table->foreign('status_id')->references('id')->on('statuses')
            ->onUpdate('cascade')->onDelete('cascade');

    });

    DB::commit();

laravel хорошо обрабатывает отношения, нет причин избегать их, и да, если вы пытаетесь в полной мере использовать красноречивые способности laravel, вам нужно создать модель для каждой таблицы. см. laravel.com/docs/5.8/красноречивые отношения

Bobby Axe 28.05.2019 22:09
Стоит ли изучать PHP в 2023-2024 годах?
Стоит ли изучать PHP в 2023-2024 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
0
1
54
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Если вы планируете использовать Eloquent для построения запросов, вам необходимо создать модель для каждой таблицы. Если вы используете построитель запросов, нет необходимости создавать модель для каждой таблицы.

Другие вопросы по теме