mpyw / laravel-mysql-system-variable-manager
MySqlConnection 的一个小型扩展,用于管理会话系统变量
v2.0.3
2023-03-15 02:01 UTC
Requires
- php: ^8.0
- ext-pdo: *
- illuminate/database: ^9.0 || ^10.0 || ^11.0
- illuminate/support: ^9.0 || ^10.0 || ^11.0
- mpyw/laravel-pdo-emulation-control: ^2.0.2
- mpyw/unclosure: ^3.0
Requires (Dev)
- nunomaduro/larastan: >=1.0
- orchestra/testbench: *
- orchestra/testbench-core: >=7.0
- phpstan/extension-installer: >=1.1
- phpstan/phpstan: >=1.1
- phpunit/phpunit: >=9.5
README
MySqlConnection
的一个小型扩展,用于管理 会话 系统变量
要求
安装
composer require mpyw/laravel-mysql-system-variable-manager
基本用法
重要
默认实现由 MySqlConnectionServiceProvider
提供,但是,包发现不可用。请注意,您必须自己将其注册到 config/app.php
中。
<?php return [ /* ... */ 'providers' => [ /* ... */ Mpyw\LaravelMySqlSystemVariableManager\MySqlConnectionServiceProvider::class, /* ... */ ], ];
<?php use Illuminate\Support\Facades\DB; // Assign an auto-recoverable system variable // The variable is reassigned on accidental disconnections DB::setSystemVariable('long_query_time', 10.0); // Assign a system variable without auto-recovery DB::setSystemVariable('long_query_time', 10.0, false); // Assign multiple variables DB::setSystemVariables(['long_query_time' => 10.0, 'transaction_isolation' => 'read-committed']); // Assign a variable on a different connection DB::connection('other_mysql_connection')->setSystemVariable('long_query_time', 10.0); // Run callback temporarily assigning a variable DB::usingSystemVariable('long_query_time', 10.0, function () { /* ... */ }); // Run callback temporarily assigning multiple variables DB::usingSystemVariables(['long_query_time' => 10.0, 'transaction_isolation' => 'read-committed'], function () { /* ... */ }); // Run callback replacing current value // NOTE: You MUST declare closure return types. DB::usingSystemVariables( [ 'long_query_time' => function (float $currentValue): float { return $currentValue + 5.0; }, 'sql_mode' => function (string $currentValue): string { return str_replace('ONLY_FULL_GROUP_BY', '', $currentValue); }, ], function () { /* ... */ } );
注意
不要直接使用 DB::disconnect()
,否则自动恢复将不会被触发。
请使用 DB::connection()->disconnect()
代替。
高级用法
提示
您可以通过自己的方式使用 ManagesSystemVariables
特性扩展 MySqlConnection
。
<?php namespace App\Providers; use App\Database\MySqlConnection; use Illuminate\Database\Connection; use Illuminate\Support\ServiceProvider; class DatabaseServiceProvider extends ServiceProvider { public function register(): void { Connection::resolverFor('mysql', function (...$parameters) { return new MySqlConnection(...$parameters); }); } }
<?php namespace App\Database; use Illuminate\Database\Connection as BaseMySqlConnection; use Mpyw\LaravelMySqlSystemVariableManager\ManagesSystemVariables; class MySqlConnection extends BaseMySqlConnection { use ManagesSystemVariables; public function withoutForeignKeyChecks(callable $callback, ...$args) { return $this->usingSystemVariable('foreign_key_checks', false, $callback, ...$args); } public function allowingPartialGroupBy(callable $callback, ...$args) { return $this->usingSystemVariable('sql_mode', function (string $mode): string { return str_replace('ONLY_FULL_GROUP_BY', '', $mode); }, $callback, ...$args); } }
<?php use App\Post; use Illuminate\Support\Facades\Auth; use Illuminate\Support\Facades\DB; $post = new Post(); $post->user()->associate(Auth::user()); $post->save(); DB::withoutForeignKeyChecks(function () use ($post) { $post->user()->associate(null); $post->save(); });