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

Содержание

  • Eloquent ORM
  • Миграции
  • Сиды
  • Query Builder
  • Связи между моделями
  • Фасад DB
  • Работа со схемой
    • Миграции
    • Сиды
    • Схема (Schema)

Другие форматы

  • RevealJS
  1. ИСиТ
  2. РВПсИПП
  3. Теория
  4. Модели и базы данных в Laravel

Модели и базы данных в Laravel

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

Бизюк Андрей

ВГТУ

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

3 декабря 2024 г.

В Laravel используется паттерн проектирования “Модель-Вид-Контроллер” (MVC), в котором модель отвечает за взаимодействие с базой данных. Laravel предоставляет несколько инструментов для работы с базами данных и моделями.

Eloquent ORM

Eloquent ORM - это объектно-реляционное отображение (ORM), которое предоставляет простой и удобный способ взаимодействия с базой данных. Его основные преимущества:

  • Простота настройки: Eloquent требует минимальной настройки и позволяет работать с различными типами СУБД (MySQL, PostgreSQL, SQLite, SQL Server и т.д.).

  • ActiveRecord: Eloquent использует шаблон проектирования ActiveRecord, который позволяет работать с таблицами базы данных как с объектами.

  • Query Builder: Eloquent также предоставляет Query Builder, который позволяет строить SQL-запросы с помощью цепочек методов.

  • Миграции и сиды: Laravel предоставляет инструменты для управления схемой базы данных и ее заполнения тестовыми данными.

Миграции

Миграции - это инструмент Laravel для управления схемой базы данных. Миграции позволяют создавать и изменять таблицы базы данных с помощью простых PHP-классов, не прибегая к написанию SQL-кода. Преимущества миграций:

  • Кросс-платформенность: Миграции позволяют легко переносить приложение между различными СУБД.

  • Версионирование: Миграции позволяют отслеживать изменения в схеме базы данных и легко возвращаться к предыдущим версиям.

  • Совместная работа: Миграции облегчают совместную работу над проектом, так как все изменения в схеме базы данных хранятся в виде кода.

Сиды

Сиды - это инструмент Laravel для заполнения базы данных тестовыми данными. Сиды позволяют создавать файлы с наборами данных для заполнения таблиц, что упрощает тестирование и демонстрацию приложения.

Query Builder

Query Builder - это инструмент Laravel для создания SQL-запросов с помощью цепочек методов. Query Builder позволяет строить сложные запросы, не прибегая к написанию сырого SQL-кода.

Связи между моделями

Связи между моделями: Laravel предоставляет несколько типов связей между моделями, которые позволяют легко получать и манипулировать связанными данными:

  • One-to-One (один-ко-одному)

  • One-to-Many (один-ко-многим)

  • Many-to-Many (многие-ко-многим)

  • Has-One-Through (один-через-одного)

  • Has-Many-Through (многие-через-многих)

  • Many-to-Many Polymorphic (многие-ко-многим полиморфно)

  • Morph-One (один полиморфно)

  • Morph-Many (многие полиморфно)

  • Morph-To-Many (многие-к-многим полиморфно с промежуточной таблицей)

В Laravel модели представляют собой классы PHP, которые отображают таблицы базы данных. Модели наследуются от базового класса Eloquent и предоставляют различные методы для работы с данными.

Чтобы создать модель в Laravel, можно использовать команду Artisan:

php artisan make:model ModelName

Эта команда создаст файл PHP с классом модели в каталоге app/Models. Модель может быть связана с таблицей базы данных с помощью свойства $table или, если имя таблицы соответствует имени модели (во множественном числе и в нижнем регистре), Laravel автоматически определит ее.

Для работы с моделями и базами данных в Laravel также можно использовать фасад DB, который предоставляет различные методы для выполнения SQL-запросов и работы с результатами.

Фасад DB

Фасад DB в Laravel предоставляет простой и удобный интерфейс для работы с базой данных, позволяя выполнять SQL-запросы и работать с результатами. Фасад DB является частью компонента Query Builder, который позволяет строить SQL-запросы с помощью цепочек методов, не прибегая к написанию сырого SQL-кода.

Фасад DB предоставляет следующие основные методы:

  1. select(): Выполняет запрос SELECT и возвращает массив результатов.
$results = DB::select('select * from users where id = ?', [1]);
  1. insert(): Вставляет новую запись в таблицу.
DB::insert('insert into users (id, name) values (?, ?)', [1, 'John']);
  1. update(): Обновляет существующую запись в таблице.
DB::update('update users set name = ? where id = ?', ['John', 1]);
  1. delete(): Удаляет запись из таблицы.
DB::delete('delete from users where id = ?', [1]);
  1. table(): Возвращает экземпляр объекта Query Builder для работы с конкретной таблицей.
$users = DB::table('users')->where('id', 1)->first();
  1. raw(): Позволяет вставлять сырой SQL-код в запросы.
$results = DB::select(DB::raw('select * from users where id = 1'));
  1. transaction(): Выполняет набор операций в транзакции.
DB::transaction(function () {
    DB::insert('insert into users (id, name) values (?, ?)', [1, 'John']);
    DB::insert('insert into users (id, name) values (?, ?)', [2, 'Jane']);
});

Фасад DB также предоставляет методы для работы со схемой базы данных, такие как создание таблиц, индексов и ограничений.

Пример использования фасада DB для выполнения запроса SELECT:

$results = DB::select('select * from users where id = ?', [1]);

foreach ($results as $result) {
    echo $result->name;
}

Пример использования фасада DB для выполнения запроса INSERT:

DB::insert('insert into users (id, name) values (?, ?)', [1, 'John']);

Пример использования фасада DB для выполнения запроса UPDATE:

DB::update('update users set name = ? where id = ?', ['John', 1]);

Пример использования фасада DB для выполнения запроса DELETE:

DB::delete('delete from users where id = ?', [1]);

Работа со схемой

Laravel предоставляет несколько инструментов для работы со схемой базы данных. Они позволяют создавать, изменять и удалять таблицы, индексы и ограничения без необходимости писать сырой SQL-код.

Миграции

Миграции - это инструмент Laravel для управления изменениями в схеме базы данных. Они позволяют создавать и изменять таблицы, индексы и ограничения с помощью простых PHP-классов. Миграции также позволяют откатить изменения в базе данных, если это необходимо.

Чтобы создать миграцию, используйте команду Artisan:

php artisan make:migration create_users_table

Эта команда создаст файл миграции в каталоге database/migrations. В этом файле можно определить методы up() и down(), которые будут выполняться при выполнении миграции и ее откате соответственно.

Пример миграции для создания таблицы users:

use Illuminate\Support\Facades\Schema;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;

class CreateUsersTable extends Migration
{
    /**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        Schema::create('users', function (Blueprint $table) {
            $table->increments('id');
            $table->string('name');
            $table->string('email')->unique();
            $table->timestamp('created_at')->useCurrent();
            $table->timestamp('updated_at')->useCurrent()->useCurrentOnUpdate();
        });
    }

    /**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        Schema::dropIfExists('users');
    }
}

Сиды

Сиды - это инструмент Laravel для заполнения базы данных тестовыми данными. Они позволяют создавать файлы с наборами данных, которые будут вставлены в таблицы базы данных. Сиды могут быть полезны для тестирования приложения или для создания демонстрационных данных.

Чтобы создать сид, используйте команду Artisan:

php artisan make:seeder UsersTableSeeder

Эта команда создаст файл сида в каталоге database/seeds. В этом файле можно определить метод run(), который будет выполняться при выполнении сида.

Пример сида для заполнения таблицы users:

use Illuminate\Database\Seeder;
use Illuminate\Support\Facades\DB;

class UsersTableSeeder extends Seeder
{
    /**
     * Run the database seeds.
     *
     * @return void
     */
    public function run()
    {
        DB::table('users')->insert([
            'name' => 'John Doe',
            'email' => 'john@example.com',
            'created_at' => now(),
            'updated_at' => now(),
        ]);
    }
}

Схема (Schema)

Схема (Schema) - это компонент Laravel, который предоставляет простой и удобный интерфейс для работы со схемой базы данных. Он позволяет создавать, изменять и удалять таблицы, индексы и ограничения с помощью методов PHP.

Пример использования схемы для создания таблицы users:

use Illuminate\Support\Facades\Schema;
use Illuminate\Database\Schema\Blueprint;

Schema::create('users', function (Blueprint $table) {
    $table->increments('id');
    $table->string('name');
    $table->string('email')->unique();
    $table->timestamp('created_at')->useCurrent();
    $table->timestamp('updated_at')->useCurrent()->useCurrentOnUpdate();
});

Пример использования схемы для добавления индекса в таблицу users:

Schema::table('users', function (Blueprint $table) {
    $table->index('email');
});

Пример использования схемы для удаления таблицы users:

Schema::dropIfExists('users');

Обратите внимание, что при использовании схемы необходимо импортировать необходимые классы с помощью оператора use.

Миграции, сиды и схема - это мощные инструменты Laravel, которые облегчают работу со схемой базы данных. Они позволяют создавать, изменять и удалять таблицы, индексы и ограничения с помощью простых PHP-классов, не прибегая к написанию сырого SQL-кода.

Наверх
Шаблоны в Laravel
Формы и валидация в Laravel