Кафедра ИСиТ УО ВГТУ
  • Специальности
    • Экономика электронного бизнеса
    • Информационные системы
    • Information Control Systems
  • Каталог
  • Сайт кафедры
  • Сервисы
    • GitLab
    • ownCloud
    • JupyterHub
    • JupyterHub 2
    • VNC
    • Soft
  1. ИСиТ
  2. РВПсИПП
  3. Практика
  4. Лаб. работа “Работа с базами данных в Symfony”
  • ИСиТ
    • АОС
      • Теория
        • Введение в операционные системы
        • Управление памятью
        • Управление процессами
        • Система ввода-вывода
        • Информационная безопасность
        • Виртуализация
      • Практика
    • РВПсИПП
      • Теория
        • Настройка среды разработки для 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. Лаб. работа “Работа с базами данных в Symfony”

Лаб. работа “Работа с базами данных в Symfony”

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

Бизюк Андрей

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

29 февраля 2024 г.

Цель работы:

  • Изучить основные принципы работы с базами данных в Symfony
  • Научиться создавать и настраивать базу данных для приложения Symfony
  • Изучить основные методы работы с сущностями и объектами базы данных
  • Научиться создавать и выполнять SQL-запросы с помощью Doctrine ORM

Задачи:

  1. Установить и настроить фреймворк Symfony.
  2. Создать новый проект Symfony.
  3. Настроить подключение к базе данных.
  4. Создать новую сущность и соответствующую таблицу в базе данных с помощью Doctrine ORM.
  5. Добавить новые поля в существующую сущность и обновить схему базы данных.
  6. Научиться создавать, обновлять и удалять объекты сущности в базе данных.
  7. Научиться выполнять SQL-запросы к базе данных с помощью Doctrine ORM.
  8. Научиться использовать транзакции при работе с базой данных.
  9. Научиться использовать пагинацию для вывода большого количества данных из базы данных.
  10. Научиться создавать и использовать собственные запросы к базе данных с помощью Doctrine DBAL.

Результаты работы:

  • Настроенный проект Symfony с подключением к базе данных
  • Созданная сущность и соответствующая таблица в базе данных
  • Примеры кода для создания, обновления и удаления объектов сущности в базе данных
  • Примеры кода для выполнения SQL-запросов к базе данных с помощью Doctrine ORM
  • Примеры кода для использования транзакций и пагинации
  • Примеры кода для создания и использования собственных запросов к базе данных с помощью Doctrine DBAL

Материалы для изучения:

  • Документация Symfony: Doctrine ORM, Database and Doctrine
  • Официальный сайт Doctrine: Doctrine ORM documentation, Doctrine DBAL documentation
  • Книга “Symfony. Подробное руководство”: Глава 10. Базы данных и Doctrine
  • Видеокурс “Symfony 4. Доctrine. Работа с базой данных”: Урок 1. Установка и настройка Doctrine, Урок 2. Создание сущностей и таблиц, Урок 3. CRUD операции

Примеры заданий:

  1. Создать сущность “Пользователь” с полями “Имя”, “Электронная почта”, “Пароль” и соответствующую таблицу в базе данных.
  2. Добавить поле “Телефон” в существующую сущность “Пользователь” и обновить схему базы данных.
  3. Написать код для создания нового пользователя в базе данных.
  4. Написать код для обновления электронной почты существующего пользователя в базе данных.
  5. Написать код для удаления пользователя из базы данных по его идентификатору.
  6. Написать SQL-запрос для выбора всех пользователей, у которых электронная почта содержит домен “gmail.com”.
  7. Написать код для выполнения SQL-запроса из предыдущего задания с помощью Doctrine ORM.
  8. Написать код для создания транзакции при добавлении нового пользователя в базу данных.
  9. Написать код для вывода списка пользователей с пагинацией (10 пользователей на странице).
  10. Написать код для создания собственного запроса к базе данных с помощью Doctrine DBAL, который выбирает всех пользователей, зарегистрированных в прошлом месяце.
Наверх
Лаб. работа “Шаблоны и представления в Symfony”
Лаб. работа “Фомы и аутентификация в Symfony”