esign/laravel-database-trigger
最新稳定版本:1.5.0
Composer 安装命令:
composer require esign/laravel-database-trigger
包简介
Easily create database triggers inside of your Laravel application
README 文档
README
This package provides an easy way to manage database triggers within your Laravel application. Currently only MySQL is supported.
Installation
You can install the package via composer:
composer require esign/laravel-database-trigger
Usage
Creating triggers
To create a new database trigger, use the createTrigger method on the Schema facade.
The createTrigger method accepts two arguments: the first is the name of the trigger, while the second is a closure which receives a DatabaseTrigger object that may be used to define the new trigger:
use Esign\DatabaseTrigger\DatabaseTrigger; use Esign\DatabaseTrigger\Enums\TriggerEvent; use Esign\DatabaseTrigger\Enums\TriggerTiming; use Esign\DatabaseTrigger\Facades\Schema; Schema::createTrigger('my_trigger', function (DatabaseTrigger $trigger) { $trigger->on('posts'); $trigger->event(TriggerEvent::INSERT); $trigger->timing(TriggerTiming::BEFORE); $trigger->statement("SET NEW.title = 'Default title';"); });
Checking for trigger existence
You may check for the existence of a trigger by using the hasTrigger method:
use Esign\DatabaseTrigger\Facades\Schema; Schema::hasTrigger('my_trigger');
Dropping triggers
You may drop an existing trigger by using the dropTrigger or dropTriggerIfExists methods:
use Esign\DatabaseTrigger\Facades\Schema; Schema::dropTrigger('my_trigger'); Schema::dropTriggerIfExists('my_trigger');
Generating migrations
You may use the make:trigger artisan command to quickly generate a trigger migration:
php artisan make:trigger
This will publish a migration with the following contents:
use Esign\DatabaseTrigger\DatabaseTrigger; use Esign\DatabaseTrigger\Enums\TriggerEvent; use Esign\DatabaseTrigger\Enums\TriggerTiming; use Esign\DatabaseTrigger\Facades\Schema; use Illuminate\Database\Migrations\Migration; return new class extends Migration { public function up(): void { Schema::createTrigger('before_posts_update', function (DatabaseTrigger $trigger) { $trigger->on('posts'); $trigger->timing(TriggerTiming::BEFORE); $trigger->event(TriggerEvent::UPDATE); $trigger->statement(''); }); } public function down(): void { Schema::dropTriggerIfExists('before_posts_update'); } };
A name for the trigger will automatically be created based on the provided input. In case you want to use a diffferent trigger name, you may pass it as the first argument:
php artisan make:trigger my_trigger
Displaying existing triggers
To display a list of your existing triggers you may use the trigger:list command:
php artisan trigger:list php artisan trigger:list <connection>
Testing
composer test
License
The MIT License (MIT). Please see License File for more information.
统计信息
- 总下载量: 14.48k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 5
- 点击次数: 1
- 依赖项目数: 1
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2021-12-12