dandylion / medoo
The lightweight PHP database framework to accelerate development
Fund package maintenance!
Open Collective
paypal.me/AngelaonLai
Installs: 84
Dependents: 1
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 1 149
Type:framework
Requires
- php: >=7.3
- ext-pdo: *
Requires (Dev)
- phpunit/phpunit: ^9.0
Suggests
- ext-pdo_dblib: For MSSQL or Sybase database on Linux/UNIX platform
- ext-pdo_mysql: For MySQL or MariaDB database
- ext-pdo_oci: For Oracle database
- ext-pdo_pqsql: For PostgreSQL database
- ext-pdo_sqlite: For SQLite database
- ext-pdo_sqlsrv: For MSSQL database on both Window/Liunx platform
README
The lightweight PHP database framework to accelerate development.
Features
-
Lightweight - Portable with only one file.
-
Easy - Easy to learn and use, with a friendly construction.
-
Powerful - Supports various common and complex SQL queries, data mapping and prevents SQL injection.
-
Compatible - Supports MySQL, MSSQL, SQLite, MariaDB, PostgreSQL, Sybase, Oracle, and more.
-
Friendly - Works well with every PHP framework, such as Laravel, Codeigniter, Yii, Slim, and frameworks that support singleton extension or composer.
-
Free - Under the MIT license, you can use it anywhere, for whatever purpose.
Requirements
PHP 7.3+ and installed PDO extension.
Get Started
Install via composer
Add Medoo to the composer.json configuration file.
$ composer require catfan/medoo
And update the composer
$ composer update
// Require Composer's autoloader. require 'vendor/autoload.php'; // Use the Medoo namespace. use Dandylion\Medoo; // Connect to the database. $database = new Medoo([ 'type' => 'mysql', 'host' => 'localhost', 'database' => 'name', 'username' => 'your_username', 'password' => 'your_password' ]); $database->insert('account', [ 'user_name' => 'foo', 'email' => 'foo@bar.com' ]); $data = $database->select('account', [ 'user_name', 'email' ], [ 'user_id' => 50 ]); echo json_encode($data); // [{ // "user_name" : "foo", // "email" : "foo@bar.com", // }]
Contribution Guides
Before starting a new pull request, please ensure compatibility with other databases and write unit tests whenever possible.
Run phpunit tests
for unit testing and php-cs-fixer fix
to fix code style.
Each commit should start with a tag indicating the type of change: [fix]
, [feature]
, or [update]
.
Please keep it simple and keep it clear.
License
Medoo is released under the MIT license.
Links
-
Official website: https://medoo.in
-
Documentation: https://medoo.in/doc
-
Twitter: https://twitter.com/MedooPHP
-
Open Collective: https://opencollective.com/medoo