PHPackages                             m/db - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Database &amp; ORM](/categories/database)
4. /
5. m/db

ActiveLibrary[Database &amp; ORM](/categories/database)

m/db
====

1.0.11(2y ago)022MITPHP

Since Aug 2Pushed 2y agoCompare

[ Source](https://github.com/ptdorf/db)[ Packagist](https://packagist.org/packages/m/db)[ RSS](/packages/m-db/feed)WikiDiscussions master Synced 1mo ago

READMEChangelogDependencies (2)Versions (11)Used By (0)

m/db
====

[](#mdb)

A small mysql library.

Installation
------------

[](#installation)

```
composer require m/db

```

Usage
-----

[](#usage)

```
$db = \m\Db::open([
    "host" => "db01.internal",
    "user" => "app",
    "pass" => "secret",
    "db"   => "shop",
]);

$query = "SELECT * FROM cart WHERE user_id = :user_id";
$params = [
    "user_id" => 123,
];
$rows = $db->read($query, $params);
// returns array of associative arrays

$query = "UPDATE cart SET updated = NOW() WHERE id = :id";
$params = [
    "id" => 456,
];
$affected = $db->write($query, $params);
// returns number of affected rows
```

API
---

[](#api)

```
interface DbInterface
{
    public static function open($config);

    public function config($key = null, $value = null);
    public function read($query, array $params = []);
    public function write($query, array $params = []);
}
```

The config can be parsed from a URL and changed at will:

```
use \m\Db;

$db = Db::open("mysql://username:password@host/db");
$db = Db::open($_ENV["DATABASE_URL"]);

$currHost = $db->config("host");                   // get current config value
$oldValue = $db->config("host", "db02.internal");  // change one item, returns old value
$config   = $db->config();                         // get all config values
```

Status
------

[](#status)

[![Travis Status](https://camo.githubusercontent.com/79acc5ea1dd25aaf2532863571f02b51e6707f266301e5511957e0e626e953cf/68747470733a2f2f6170692e7472617669732d63692e6f72672f646f747365722f64622e7376673f6272616e63683d6d6173746572)](https://travis-ci.org/dotser/db)[![Latest Stable Version](https://camo.githubusercontent.com/f78dc52ed804999b361213284bdb159db147448f415c1b31b0eb6566f951d74a/68747470733a2f2f706f7365722e707567782e6f72672f6d2f64622f762f737461626c65)](https://packagist.org/packages/m/db)[![Total Downloads](https://camo.githubusercontent.com/74d2b82edb32da42c0ce80953f428fa4ea305c51a5dd6351a8d86f31aca1dd8a/68747470733a2f2f706f7365722e707567782e6f72672f6d2f64622f646f776e6c6f616473)](https://packagist.org/packages/m/db)[![Coverage Status](https://camo.githubusercontent.com/510e17e59c41505d82b7e92ec42c0f2e0ded00e78097a43975eca710e335d25f/68747470733a2f2f636f766572616c6c732e696f2f7265706f732f6769746875622f646f747365722f64622f62616467652e7376673f6272616e63683d6d6173746572)](https://coveralls.io/github/dotser/db?branch=master)

###  Health Score

23

—

LowBetter than 27% of packages

Maintenance20

Infrequent updates — may be unmaintained

Popularity6

Limited adoption so far

Community9

Small or concentrated contributor base

Maturity50

Maturing project, gaining track record

 Bus Factor1

Top contributor holds 84.8% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Every ~0 days

Total

10

Last Release

1020d ago

### Community

Maintainers

![](https://www.gravatar.com/avatar/439373b28662fac46c8eead0b1d046e0fe893944ae8ce8dd45581c6520f697a0?d=identicon)[ptdorf](/maintainers/ptdorf)

![](https://www.gravatar.com/avatar/ed8eef77ba01d40dfec9d68becf23b6cabd3c54cebb03a885012387d20b9f0d5?d=identicon)[jpedro](/maintainers/jpedro)

---

Top Contributors

[![ptdorf](https://avatars.githubusercontent.com/u/5017?v=4)](https://github.com/ptdorf "ptdorf (84 commits)")[![jpedro](https://avatars.githubusercontent.com/u/25252785?v=4)](https://github.com/jpedro "jpedro (15 commits)")

###  Code Quality

TestsPHPUnit

### Embed Badge

![Health badge](/badges/m-db/health.svg)

```
[![Health](https://phpackages.com/badges/m-db/health.svg)](https://phpackages.com/packages/m-db)
```

###  Alternatives

[doctrine/orm

Object-Relational-Mapper for PHP

10.2k285.3M6.2k](/packages/doctrine-orm)[jdorn/sql-formatter

a PHP SQL highlighting library

3.9k115.1M102](/packages/jdorn-sql-formatter)[illuminate/database

The Illuminate Database package.

2.8k52.4M9.4k](/packages/illuminate-database)[mongodb/mongodb

MongoDB driver library

1.6k64.0M546](/packages/mongodb-mongodb)[ramsey/uuid-doctrine

Use ramsey/uuid as a Doctrine field type.

90340.3M211](/packages/ramsey-uuid-doctrine)[reliese/laravel

Reliese Components for Laravel Framework code generation.

1.7k3.4M16](/packages/reliese-laravel)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
