mpyw / laravel-pdo-emulation-control
Temporarily enable/disable PDO prepared statement emulation
Installs: 78 180
Dependents: 1
Suggesters: 0
Security: 0
Stars: 2
Watchers: 2
Forks: 0
Open Issues: 0
pkg:composer/mpyw/laravel-pdo-emulation-control
Requires
- php: ^8.2
- ext-pdo: *
- illuminate/database: ^11.0 || ^12.0 || ^13.0
- illuminate/support: ^11.0 || ^12.0 || ^13.0
- mpyw/unclosure: ^3.1
Requires (Dev)
- mockery/mockery: ^1.6.12
- nunomaduro/larastan: >=3.1
- orchestra/testbench: *
- orchestra/testbench-core: >=9.0
- phpstan/extension-installer: >=1.4
- phpstan/phpstan: >=2.0
- phpunit/phpunit: >=11.0
README
Temporarily enable/disable PDO prepared statement emulation.
Requirements
| Package | Version | Mandatory | 
|---|---|---|
| PHP | ^8.2 | ✅ | 
| Laravel | ^11.0 || ^12.0 | ✅ | 
| PHPStan | >=2.0 | 
Note
Older versions have outdated dependency requirements. If you cannot prepare the latest environment, please refer to past releases.
Installing
composer require mpyw/laravel-pdo-emulation-control
Basic Usage
Important
The default implementation is provided by ConnectionServiceProvider, however, package discovery is not available.
Be careful that you MUST register it in config/app.php by yourself.
<?php return [ /* ... */ 'providers' => [ /* ... */ Mpyw\LaravelPdoEmulationControl\ConnectionServiceProvider::class, /* ... */ ], ];
<?php use Illuminate\Support\Facades\DB; // Temporarily enable PDO prepared statement emulation. DB::emulated(function () { // Your code goes here }); // Temporarily disable PDO prepared statement emulation. // (Only if you've already configured your connection by options [PDO::ATTR_EMULATE_PREPARES => true]) DB::native(function () { // Your code goes here });
Important
Note that DB::getPdo() DB::getReadPdo() are not always called even though these methods directly touch the PDO instances.
Connections are lazily resolved as possible as they can.
PDO::setAttribute() is called only after the PDO instance has been created and the socket connection to the database has been really established.
Advanced Usage
Tip
You can extend Connection classes with ControlsEmulation trait by yourself.
<?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\LaravelPdoEmulationControl\ControlsEmulation; class MySqlConnection extends BaseMySqlConnection { use ControlsEmulation; }