定制 mepihindeveloper/php-sql-migration 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

mepihindeveloper/php-sql-migration

Composer 安装命令:

composer require mepihindeveloper/php-sql-migration

包简介

Component for working with SQL migrations

README 文档

README

Компонент для работы с SQL миграциями.

В компоненте реализован основной класс SqlMigration, который выполняет базовые операции по работе с миграциями. Большинство методов возвращает наборы данных или логические значения. Данный подход позволит написать практически любую обертку для собственных нужд.

Как пример реализации обертки был реализован класс ConsoleSqlMigration, которые наследуется от SqlMigration и переопределяет его методы. Переопределение первоначально вызывает parent:: после чего реализует дополнительную логику в выводе сообщений в консоль (терминал).

Для реализации компонента необходимо передать класс реализующий интерфейс DatabaseInterface и массив настроек. Обязательными параметрами в настройках являются:

  • schema - схема в базе данных для миграций
  • table - таблица в базе данных для миграций
  • path - путь в файловой структуре для папки с миграциями

Компонент самостоятельно проверяет и создает необходимые (указанные) схемы, таблицы и папки при наличии заранее определенных разрешений (прав). Для корректной работы с базой данных необходимо заранее установить соединение с ней.

Для использования компонента достаточно создать экземпляр класса и вызвать нужный метод:

$sqlMigration = new SqlMigration($database, [
	'schema' => 'migrations',
	'table' => 'migration',
	'path' => 'migrations'
]);

$sqlMigration->up();

Для работы с консолью достаточно создать файл управления миграциями и вызвать его через php FILE ACTION PARAMS:

  1. php migrate up
  2. php migrate down 2

Файл автоматической обработки таких запросов может выглядеть следующим образом:

#!/usr/bin/env php
<?php
declare(strict_types = 1);

use mepihindeveloper\components\{Console, ConsoleSqlMigration, Database};

require_once 'vendor/autoload.php';

$database = new Database([
	'dbms' => 'pgsql',
	'host' => 'localhost',
	'dbname' => 'php',
	'user' => 'www-data',
	'password' => 'pass'
]);
$database->connect();
$sqlMigration = new ConsoleSqlMigration($database, [
	'schema' => 'migrations',
	'table' => 'migration',
	'path' => 'migrations'
]);

$method = $argv[1];
$params = $argv[2] ?? null;

if (!method_exists($sqlMigration, $method)) {
	Console::writeLine("Неопознанная команда '{$method}'", Console::FG_RED);
	exit;
}

return is_null($params) ? $sqlMigration->$method() : $sqlMigration->$method($params);

Структура

src/
--- exceptions/
--- interfaces/
--- SqlMigration.php
--- ConsoleSqlMigration.php

В директории exceptions хранятся специальные исключения компонента: SqlMigrationException.

В директории interfaces хранятся необходимые интерфейсы, которые необходимо имплементировать в при реализации собственного класса SqlMigration.

Класс SqlMigration реализует интерфейс SqlMigrationInterface для управления SQL миграциями.

Доступные методы

Метод Аргументы Возвращаемые данные Исключения Описание
public function up(int $count = 0) $count Количество миграций (0 - относительно всех) array SqlMigrationException Применяет указанное количество миграций
public function down(int $count = 0) $count Количество миграций (0 - относительно всех) array SqlMigrationException Отменяет указанное количество миграций
public function history(int $limit = 0) $limit Ограничение длины списка (null - полный список) array Возвращает список сообщений о примененных миграций
public function create(string $name) $name Название миграции void RuntimeException|SqlMigrationException Создает новую миграцию и возвращает сообщение об успешном создании миграции
__construct(DatabaseInterface $database, array $settings) $database Компонент работы с базой данных; array $settings Массив настроек SqlMigrationException Конструктор класса
public function initSchemaAndTable() bool SqlMigrationException Создает схему и таблицу в случае их отсутствия
public function __destruct() Деструктор класса
protected function getNotAppliedList() array Возвращает список не примененных миграций
protected function getHistoryList(int $limit = 0) $limit Ограничение длины списка (0 - полный список) array Возвращает список примененных миграций
protected function execute(array $list, int $count, string $type) $list Массив миграций; $count Количество миграций для применения; $type Тип миграции (up/down) array RuntimeException Выполняет миграции
protected function addHistory(string $name) $name Наименование миграции bool SqlMigrationException Добавляет запись в таблицу миграций
protected function removeHistory(string $name) $name Наименование миграции bool SqlMigrationException Удаляет миграцию из таблицы миграций
protected function validateName(string $name) $name Название миграции void SqlMigrationException Проверяет имя миграции на корректность
protected function generateName(string $name) string $name Название миграции string Создает имя миграции по шаблону: m{дата в формате Ymd_His}_name

Контакты

Вы можете связаться со мной в социальной сети ВКонтакте: ВКонтакте: Максим Епихин

Если удобно писать на почту, то можете воспользоваться этим адресом: mepihindeveloper@gmail.com

Мой канал на YouTube, который посвящен разработке веб и игровых проектов: YouTube: Максим Епихин

Поддержать меня можно переводом на Яндекс.Деньги: Денежный перевод

统计信息

  • 总下载量: 7
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 2
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 2
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2021-04-07

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固