Модели и базы данных в Laravel
В 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 с классом модели в каталоге app/Models
. Модель может быть связана с таблицей базы данных с помощью свойства $table
или, если имя таблицы соответствует имени модели (во множественном числе и в нижнем регистре), Laravel автоматически определит ее.
Для работы с моделями и базами данных в Laravel также можно использовать фасад DB
, который предоставляет различные методы для выполнения SQL-запросов и работы с результатами.
Фасад DB
Фасад DB в Laravel предоставляет простой и удобный интерфейс для работы с базой данных, позволяя выполнять SQL-запросы и работать с результатами. Фасад DB является частью компонента Query Builder, который позволяет строить SQL-запросы с помощью цепочек методов, не прибегая к написанию сырого SQL-кода.
Фасад DB предоставляет следующие основные методы:
- select(): Выполняет запрос SELECT и возвращает массив результатов.
- insert(): Вставляет новую запись в таблицу.
- update(): Обновляет существующую запись в таблице.
- delete(): Удаляет запись из таблицы.
- table(): Возвращает экземпляр объекта Query Builder для работы с конкретной таблицей.
- raw(): Позволяет вставлять сырой SQL-код в запросы.
- 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 для выполнения запроса UPDATE:
Пример использования фасада DB для выполнения запроса DELETE:
Работа со схемой
Laravel предоставляет несколько инструментов для работы со схемой базы данных. Они позволяют создавать, изменять и удалять таблицы, индексы и ограничения без необходимости писать сырой SQL-код.
Миграции
Миграции - это инструмент Laravel для управления изменениями в схеме базы данных. Они позволяют создавать и изменять таблицы, индексы и ограничения с помощью простых PHP-классов. Миграции также позволяют откатить изменения в базе данных, если это необходимо.
Чтобы создать миграцию, используйте команду Artisan:
Эта команда создаст файл миграции в каталоге 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:
Эта команда создаст файл сида в каталоге 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
:
Пример использования схемы для удаления таблицы users
:
Обратите внимание, что при использовании схемы необходимо импортировать необходимые классы с помощью оператора use
.
Миграции, сиды и схема - это мощные инструменты Laravel, которые облегчают работу со схемой базы данных. Они позволяют создавать, изменять и удалять таблицы, индексы и ограничения с помощью простых PHP-классов, не прибегая к написанию сырого SQL-кода.