shakahl / laravel-eloquent-mysqli
MySQLi driver (connector) for Laravel 8.x Eloquent database
Installs: 5 603
Dependents: 0
Suggesters: 0
Security: 0
Stars: 21
Watchers: 3
Forks: 15
Open Issues: 3
Requires
- php: >=7.2
- illuminate/contracts: 8.*
- illuminate/database: 8.*
- illuminate/support: 8.*
Requires (Dev)
- phpunit/phpunit: ~5.7
This package is not auto-updated.
Last update: 2024-11-10 03:25:55 UTC
README
MySQLi driver (connector) for Laravel 8.x Eloquent database
Installation
- Install via composer
composer require shakahl/laravel-eloquent-mysqli
- After installing, add provider on config/app.php on your project.
// app.php 'providers' => [ ... 'LaravelEloquentMySQLi\MySQLiServiceProvider', ],
Usage
You should configure your database connection to use the mysqli
driver.
Example
//... 'connections' => [ 'mysql' => [ 'driver' => 'mysqli', // Sets mysqli driver 'host' => env('DB_HOST', 'localhost'), 'port' => env('DB_PORT', 3306), 'database' => env('DB_DATABASE', 'forge'), 'username' => env('DB_USERNAME', 'forge'), 'password' => env('DB_PASSWORD', ''), 'charset' => env('DB_CHARSET', 'utf8'), 'collation' => env('DB_COLLATION', 'utf8_unicode_ci'), 'prefix' => env('DB_PREFIX', ''), 'timezone' => env('DB_TIMEZONE', '+00:00'), 'strict' => env('DB_STRICT_MODE', false), ], ] //...
Notes
Accessing underlying mysqli instance
There are some inconsistent methods since Laravel only supports PDO officially. You can access the raw, underlying MySQLi instance using the following methods on a connection instance:
$mysqli = DB::connection()->getMySqli(); // or $mysqli = DB::connection()->getReadMySqli(); // or $mysqli = DB::connection()->getPdo(); // or $mysqli = DB::connection()->getReadPdo();
Escaping
Unfortunately PHP's mysqli driver does not support named parameter binding so this connector uses custom implementation for it.