170 похожих чатов

Всем привет, кто то сталкивался с таким кейсом. Создаю пакет

для ларавел, в проекте будут свои миграции. Мне нужно что бы миграции когда выполнялись (запускалась пользователем), сама история миграций писалась не в общую таблицу историй миграций, а в свою костюмную как например в CakePHP. Есть идеии как такое можно сделать?

19 ответов

28 просмотров

php artisan make:migration create_posts_table --path=/database/migrations/posts

Vitalii-Halytskyi Автор вопроса
Dimas_mj73
php artisan make:migration create_posts_table --pa...

это команда просто на создание миграции, а у меня проблема с историей миграций, как она записывается, может есть идеи какие 6 часов уже сижу

Vitalii-Halytskyi Автор вопроса
Dimas_mj73
История изменений конкретной миграции?

нет, вот пример как для CakePHP делали когда каждый модуль пишет историю в разные таблицы

если идёт речь о том, что ларавель кидает всё в таблицу migrations: там модуль миграции ларавеля юзает одну таблицу. в теории его можно заоверрайдить и сделать так, чтобы он по дефолту складировал в обычную таблицу а от либки в другую. но я не вижу ни одной причины делать это.

Vitalii-Halytskyi Автор вопроса
ThunderAL
если идёт речь о том, что ларавель кидает всё в та...

у нас модули не зависимы друг от друга или очень слабо связаны, бывают кесы когда нужно откатить миграции только по 1 модулю, модулей в системе свыше 300 и когда пишутся в 1 таблицу все, то порядок миграций по времени может пересекаться (миграции модулей перемешиваются) и получается что откатить 1 модуль невозможно, классическая проблема с миграциями получается

Vitalii Halytskyi
у нас модули не зависимы друг от друга или очень с...

понимаю, но разделение на разные таблицы это точно не решит. там смысл в том, что оно собирает строчки из бд, сортирует по дате и выполняет down в файлах миграции. логично, если сделать несколько таблиц и привязать всё это к ядру, то оно также с них стянет миграции и также откатит всё. лучше сделать отдельную либку, которая разделяет всю пачку миграций на отдельные "потоки". механика та же: оверрайдим класс с миграцией и опрашиваем все либки (там в package.json в extra можно что-то запихать для идентификации), разделяем на "модули/потоки" миграций и откатываемся как хотим.

ThunderAL
понимаю, но разделение на разные таблицы это точно...

PS у меня на одном проекта примерно та же проблема, но в другом ключе (что ларка очень плохо в модульность). решили просто через несколько инстансов ларавеля, скоро будет перетаскивать всё это на симфони

Vitalii-Halytskyi Автор вопроса
ThunderAL
PS у меня на одном проекта примерно та же проблема...

доктрина так умеет ... в нашей вариации пакетов под симфони это решено

Vitalii-Halytskyi Автор вопроса
ThunderAL
PS у меня на одном проекта примерно та же проблема...

ну ты клиенту не объяснишь что под каждый пакет нужно отдельный "микросервис"

Vitalii Halytskyi
доктрина так умеет ... в нашей вариации пакетов по...

welp. тогда, решение только одно: сносим часть с миграцией ларавеля и приклеиваем миграцию от того, что больше нравится и работает) PS команду можно снести через провайдер, а лучше перезаписать её и кидать эцепшн с поясняловкой, что надо запускать другую команду чтобы было всё норм

Vitalii-Halytskyi Автор вопроса
ThunderAL
welp. тогда, решение только одно: сносим часть с м...

в конечного клиента вообще наш набор команд, но не хочется лепить сразу какие-то обходные пути, хочется максимально стандартными средствами решить

Vitalii Halytskyi
в конечного клиента вообще наш набор команд, но не...

я понимаю что хочется сделать, но в ларке такого нет. есть класс Illuminate\Database\Migrations\Migrator именно он отвечает за миграцию и откат, можно с ним немного поколдовать и перезписать в сервис провайдере либки (которая будет грузится после ядра и будет перезаписывать ссылку на этот класс для инжектора на твой кастомный, тем самым, изменяя механику дефолтной команды) я бы в таком случае оставил таблицу миграций и добавил бы туда nullable колонку module:varchar и по ней бы получал миграцию модуля и его "локальную" историю и записывал бы туда название модуля из композера при накате миграции но это всё звучит как костыль

кажется, его решают через migrate:fresh XD

Vitalii-Halytskyi Автор вопроса
ThunderAL
кажется, его решают через migrate:fresh XD

а как пакеты под ларавел, что никто не пишет свою историю миграций?

Vitalii Halytskyi
а как пакеты под ларавел, что никто не пишет свою ...

пишут. чаще всего пакеты любят делать команду ./artisan shit:install или ещё что-то и тупо копируют свои миграции тебе в папку с миграциями

Vitalii-Halytskyi Автор вопроса
Vitalii-Halytskyi Автор вопроса
Элин
Да да

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

Похожие вопросы

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта