vectorface / mysqlite
Select MySQL compatibility functions for PDO's SQLite driver
Installs: 37 849
Dependents: 1
Suggesters: 0
Security: 0
Stars: 35
Watchers: 13
Forks: 7
Open Issues: 0
pkg:composer/vectorface/mysqlite
Requires
- php: ^8.0.0
- ext-pdo: *
Requires (Dev)
- phpunit/phpunit: ^9
- squizlabs/php_codesniffer: ~2.0
README
MySQLite is an easy way to add MySQL functions to SQLite accessed through PDO. This can be useful for testing and development where an SQLite database may be more practical than a real MySQL database.
Usage
Using MySQLite is meant to be a one-step affair, with no configuration required:
use Vectorface\MySQLite\MySQLite; // Create a PDO instance on an SQLite database $pdo = new PDO('sqlite::memory:'); // Create compatibility functions for use within that database connection. MySQLite::createFunctions($pdo); // Use it. $three = $pdo->query("SELECT BIT_OR(1, 2)")->fetch(PDO::FETCH_COLUMN); // Wait... That works now?!? What the what?!?
It is also possible to use it as a one-liner:
$pdo = MySQLite::createFunctions(new PDO('sqlite::memory:'));
You can get a list of supported functions with MySQLite::getFunctionList().
Limitations
MySQLite only provides a limited subset of MySQL functions. There are a lot of MySQL functions, so there's both a developer cost and performance penalty to adding them all.
If you want to add more, it's easy. You only need to add a function called mysql_[function name] into one of the traits in src/Vectorface/MySQLite/MySQL.
For example, to create a function FOO() with silly behavior in String.php:
... public static function mysql_foo($foo) { if ($foo == "foo") { return "bar"; } return $foo; } ...
With the above definition present, String::mysql_foo will automatically be registered with MySQLite::createFunctions($pdo) is used.