Кафедра ИСиТ УО ВГТУ
  • Специальности
    • Экономика электронного бизнеса
    • Информационные системы
    • Information Control Systems
  • Каталог
  • Сайт кафедры
  • Сервисы
    • GitLab
    • ownCloud
    • JupyterHub
    • JupyterHub 2
    • VNC
    • Soft
  1. ИСиТ
  2. РВПсИПП
  3. Практика
  4. Лаб. работа 3 “Создание моделей, миграций и сидеров”
  • ИСиТ
    • АОС
      • Теория
        • Введение в операционные системы
        • Управление памятью
        • Управление процессами
        • Система ввода-вывода
        • Информационная безопасность
        • Виртуализация
      • Практика
    • РВПсИПП
      • Теория
        • Настройка среды разработки для PHP
        • Разработка web-приложений на базе фреймворков
        • Основы Laravel
        • Шаблоны в Laravel
        • Модели и базы данных в Laravel
        • Формы и валидация в Laravel
        • Аутентификация и авторизация в Laravel
        • Создание REST API в Laravel
        • Работа с файлами и изображениями в Laravel
        • Тестирование и отладка в Laravel
        • Введение в фреймворк Symfony
        • Маршруты и контроллеры в Symfony
        • Шаблоны и Twig в Symfony
        • Формы и валидация в Symfony
        • Доступ к базам данных в Symfony
        • Аутентификация и авторизация в Symfony
        • Сервисы и зависимости в Symfony
        • Создание REST API в Symfony
        • Работа с файлами и медиа в Symfony
        • Сравнение и выбор фреймворка
        • Развертывание веб-приложения
      • Практика
        • Лаб. работа 1 “Создание нового приложения Laravel”
        • Лаб. работа 2 “Добавление главной страницы и базовых маршрутов”
        • Лаб. работа 3 “Создание моделей, миграций и сидеров”
        • Лаб. работа 4 “Создание индексных страниц и пагинация”
        • Лаб. работа 5 “Создание форм для работы с сущностями”
        • Лаб. работа 6 “Работа с файлами (эмуляция S3-хранилища)”
        • Лаб. работа “Создание маршрутов в Laravel”
        • Лаб. работа “Работа с базами данных в Laravel”
        • Лаб. работа “Работа с формами в Laravel”
        • Лаб. работа “Аутентификация и авторизация в Laravel”
        • Лаб. работа “Работа с файлами в Laravel”
        • Лаб. работа “Тестирование и оптимизация в Laravel”
        • Лаб. работа “Создание REST API в Laravel”
        • Лаб. работа “Основы Symfony”
        • Лаб. работа “Шаблоны и представления в Symfony”
        • Лаб. работа “Работа с базами данных в Symfony”
        • Лаб. работа “Фомы и аутентификация в Symfony”
        • Лаб. работа “Сервисы и зависимости в Symfony”
        • Лаб. работа “REST API в Symfony”
        • Лаб. работа “Работа с медиа контентом в Symfony”
        • Лаб. работа “Создание и развертывание проекта”
    • ПСП
      • Теория
        • Введение
        • Протокол HTTP
        • Программирование с использованием сокетов
        • Введение в PHP
        • Работа с базами данных в PHP
        • Объектно-ориентированные возможности PHP
        • Настройка среды разработки для PHP
        • Разработка web-приложений на базе фреймворков
      • Практика
        • Программное обеспечение
        • Регистрация в JupyterHub
        • Лаб. работа “Почтовые протоколы”
        • Лаб. работа “Протокол FTP”
        • Лаб. работа “Протокол HTTP”
        • Лаб. работа “Программирование сетевых приложений с использованием сокетов”
        • Лаб. работа “Основы PHP”
        • Лаб. работа “Массивы в PHP”
        • Лаб. работа “Создание веб-приложений с использованием Slim”
    • Компьютерные сети
      • Теория
        • Введение в компьютерные сети
        • Топологии сетей
        • Кодирование и мультиплексирование
        • Стеки протоколов
        • Адресация в компьютерных сетях
        • Система доменных имен (DNS)
        • Программирование с использованием сокетов
        • Введение в PHP
        • Протокол HTTP
        • Введение в компьютерные сети
      • Практика
        • Программное обеспечение
        • Регистрация в JupyterHub
        • Лаб. работа “Почтовые протоколы”
        • Лаб. работа “Протокол FTP”
        • Лаб. работа “Протокол HTTP”
        • Лаб. работа “Программирование сетевых приложений с использованием сокетов”
        • Лаб. работа “Основы PHP”
        • Лаб работа “Массивы в PHP”
    • РиОИИС
      • Теория
        • Классификация оптимизационных задач
        • Генетические алгоритмы
        • Системы массового обслуживания
        • Теория игр
        • Машинное обучение
        • Глубокое обучение (Deep learning)
        • Основы функционального программирования
        • Основы программирования на Haskell
        • Введение в логическое программирование
        • Инференция и рассуждения в логическом программировании
        • Разработка экспертных систем
        • Интеллектуальные системы и их архитектура
        • Веб-скрэйпинг
        • Сбор данных с открытых API
      • Практика
        • JupyterHub
        • Лаб. работа “Методы одномерной оптимизации”
        • Лаб. работа “Методы многомерной оптимизации”
        • Лаб. работа “Функции в Python”
        • Лаб. работа “Рекурсия в Python”
        • Лаб. работа “Итераторы в Python”
        • Лаб. работа “Генетические алгоритмы”
        • Лаб. работа “Haskell”
        • Лаб. работа “Логическое программирование”
        • Лаб. работа “Сбор данных с помощью веб-скрейпинга”
    • КСКР
      • Практика
        • Лаб. работа “Одномерные и двумерные массивы в C#”
        • Лаб. работа “Обращение матриц в C#”
    • Системное программирование
      • Теория
        • Управление памятью в Windows
        • Файловые операции в Windows
        • Управление процессами в Windows
        • Графический интерфейс Windows
        • ОС Unix
      • Практика
        • Лаб. работа “Работа с динамической памятью в Windows”
        • Лаб. работа “Операции с файлами в Windows”
        • Лаб. работа “Управление процессами в Windows”
        • Лаб. работа “Работа с виртуальной машиной Linux”
        • Лаб. работа “Язык командного энтерпритатора Shell”
        • Лаб. работа “Работа с файлами в Linux”
        • Лаб. работа “Работа с процессами в Linux”

Содержание

  • Методическая часть
  • Индивидуальные задания
  • Проверка работы
  • Примечания
  1. ИСиТ
  2. РВПсИПП
  3. Практика
  4. Лаб. работа 3 “Создание моделей, миграций и сидеров”

Лаб. работа 3 “Создание моделей, миграций и сидеров”

Разработка web-приложений с использованием программных платформ
Практика
Автор

Бизюк Андрей

Дата публикации

27 февраля 2025 г.

Цель: Научиться проектировать сложные связи между моделями, использовать фабрики и сидеры для заполнения данных.
Задачи:
- Создать несколько взаимосвязанных моделей: Post, Category, Comment, Tag.
- Реализовать связи: один-ко-многим, многие-ко-многим.
- Настроить каскадное удаление данных.


Методическая часть

1. Создание моделей и миграций

Выполните команды для создания моделей и миграций:

php artisan make:model Post -m
php artisan make:model Category -m
php artisan make:model Comment -m
php artisan make:model Tag -m

2. Настройка миграций

a. Таблица categories (database/migrations/xxxx_create_categories_table.php):

Schema::create('categories', function (Blueprint $table) {
    $table->id();
    $table->string('name');
    $table->string('slug')->unique();
    $table->timestamps();
});

b. Таблица posts (добавить внешние ключи):

Schema::create('posts', function (Blueprint $table) {
    $table->id();
    $table->string('title');
    $table->text('content');
    $table->string('image')->nullable();
    $table->foreignId('user_id')->constrained()->cascadeOnDelete();
    $table->foreignId('category_id')->constrained()->cascadeOnDelete();
    $table->timestamps();
});

c. Таблица comments:

Schema::create('comments', function (Blueprint $table) {
    $table->id();
    $table->text('text');
    $table->foreignId('user_id')->constrained()->cascadeOnDelete();
    $table->foreignId('post_id')->constrained()->cascadeOnDelete();
    $table->timestamps();
});

d. Таблица tags и связь многие-ко-многим с posts:

// Таблица tags
Schema::create('tags', function (Blueprint $table) {
    $table->id();
    $table->string('name');
    $table->string('slug')->unique();
    $table->timestamps();
});

// Промежуточная таблица post_tag
Schema::create('post_tag', function (Blueprint $table) {
    $table->foreignId('post_id')->constrained()->cascadeOnDelete();
    $table->foreignId('tag_id')->constrained()->cascadeOnDelete();
    $table->primary(['post_id', 'tag_id']);
});

3. Определение связей в моделях

a. Модель Post (app/Models/Post.php):

public function user() {
    return $this->belongsTo(User::class);
}

public function category() {
    return $this->belongsTo(Category::class);
}

public function comments() {
    return $this->hasMany(Comment::class);
}

public function tags() {
    return $this->belongsToMany(Tag::class);
}

b. Модель Comment:

public function user() {
    return $this->belongsTo(User::class);
}

public function post() {
    return $this->belongsTo(Post::class);
}

c. Модель Category:

public function posts() {
    return $this->hasMany(Post::class);
}

d. Модель Tag:

public function posts() {
    return $this->belongsToMany(Post::class);
}

4. Создание фабрик

Создайте фабрики для всех моделей:

php artisan make:factory PostFactory
php artisan make:factory CategoryFactory
php artisan make:factory CommentFactory
php artisan make:factory TagFactory

Пример фабрики PostFactory:

public function definition(): array {
    return [
        'title' => fake()->sentence(),
        'content' => fake()->paragraphs(3, true),
        'user_id' => User::factory(),
        'category_id' => Category::factory(),
        'image' => fake()->optional()->imageUrl(),
    ];
}

5. Заполнение сидеров

Измените database/seeders/DatabaseSeeder.php:

public function run(): void {
    // Создать 5 категорий
    Category::factory(5)->create();

    // Создать 10 тегов
    Tag::factory(10)->create();

    // Создать 20 постов
    Post::factory(20)
        ->has(Comment::factory(3)) // 3 комментария к каждому посту
        ->create()
        ->each(function ($post) {
            // Привязать случайные теги к постам
            $tags = Tag::inRandomOrder()->take(3)->pluck('id');
            $post->tags()->attach($tags);
        });
}

Индивидуальные задания

1. Добавление модели Like

  • Создайте модель Like с полями: user_id, likeable_type (полиморфная связь), likeable_id.
  • Реализуйте полиморфное отношение, чтобы лайки можно было ставить как постам, так и комментариям.

2. Мягкое удаление (Soft Delete)

  • Добавьте в модели Post и Comment поддержку мягкого удаления.
  • Измените миграции, добавив $table->softDeletes();.
  • Проверьте, что при удалении поста комментарии остаются в базе (если не использовать каскадное удаление).

3. Валидация slug

  • В модели Category добавьте валидацию slug через observer:

    // Создайте observer
    php artisan make:observer CategoryObserver --model=Category
  • В CategoryObserver:

    public function creating(Category $category) {
        $category->slug = Str::slug($category->name);
    }

4. Теги через строку

Модифицируйте форму создания поста:
- Добавьте поле tags (строка с тегами через запятую).
- В контроллере обработайте ввод:
php $tags = explode(',', $request->tags); foreach ($tags as $tagName) { $tag = Tag::firstOrCreate(['name' => trim($tagName)]); $post->tags()->attach($tag); }


Проверка работы

  1. Выполните миграции и сидеры:

    php artisan migrate:fresh --seed
  2. Проверьте связи через Tinker:

    php artisan tinker
    $post = Post::first();
    $post->comments; // Должен вывести комментарии
    $post->tags; // Должен вывести теги

Примечания

  • Каскадное удаление: При удалении категории все связанные посты будут удалены автоматически.
  • Полиморфные связи: Используются для гибкой привязки моделей (например, лайки к разным сущностям).
Наверх
Лаб. работа 2 “Добавление главной страницы и базовых маршрутов”
Лаб. работа 4 “Создание индексных страниц и пагинация”