initphp / database
InitPHP Database — QueryBuilder, DBAL and ORM facade for the InitORM stack, plus a server-side DataTables.js helper.
Requires
- php: ^8.1
- ext-pdo: *
- initorm/orm: ^2.0
Requires (Dev)
- ext-pdo_sqlite: *
- phpstan/phpstan: ^1.12
- phpunit/phpunit: ^10.5
- squizlabs/php_codesniffer: ^3.10
Suggests
- ext-pdo_mysql: Required for MySQL / MariaDB connections.
- ext-pdo_pgsql: Required for PostgreSQL connections.
- ext-pdo_sqlite: Required for SQLite connections.
This package is auto-updated.
Last update: 2026-05-24 20:55:30 UTC
README
A Composer-friendly, batteries-included facade over the InitORM stack — query builder, DBAL connection, ORM models and entities — plus a server-side helper for DataTables.js.
What is this?
initphp/database does not reimplement an ORM. It is the InitPHP-branded entry point to the InitORM stack:
| You write | You actually get |
|---|---|
InitPHP\Database\DB |
A static facade over InitORM\Database\Database. |
InitPHP\Database\Database |
The InitORM Database class. |
InitPHP\Database\Model |
The InitORM active-record Model. |
InitPHP\Database\Entity |
The InitORM Entity with accessor / mutator hooks. |
InitPHP\Database\Utils\Datatables\Datatables |
Original server-side DataTables.js helper — the one piece that lives in this package. |
If a feature is documented for InitORM, it works here under the InitPHP namespace.
Requirements
- PHP 8.1 or later
ext-pdoand a PDO driver for your target database (pdo_mysql,pdo_pgsql,pdo_sqlite, …)
Installation
composer require initphp/database
Quick start
<?php require __DIR__ . '/vendor/autoload.php'; use InitPHP\Database\DB; DB::createImmutable([ 'dsn' => 'mysql:host=localhost;port=3306;dbname=test;charset=utf8mb4', 'username' => 'root', 'password' => '', ]); $rows = DB::select('id', 'title', 'author_id') ->from('posts') ->where('status', '=', 1) ->orderBy('id', 'DESC') ->limit(10) ->read() ->asAssoc() ->rows(); foreach ($rows as $row) { echo $row['title'], PHP_EOL; }
Documentation
Topic-by-topic guides live in docs/:
| # | Guide |
|---|---|
| 01 | Getting started — install, connect, first query, debug & logging |
| 02 | Query Builder — select / where / join / groupBy / orderBy / limit / raw |
| 03 | CRUD — create / read / update / delete and their *Batch siblings |
| 04 | Models — table binding, soft deletes, timestamp columns, access gates |
| 05 | Entities — attribute bag, accessor / mutator hooks (and the one PHP 8.2+ pitfall) |
| 06 | Transactions — automatic retry, dry-run / test mode |
| 07 | Query log — enableQueryLog + the log connection channel |
| 08 | Datatables — server-side DataTables.js integration end-to-end |
| 09 | Multiple connections — secondary databases via DB::connect() / Model::$credentials |
| 10 | Upgrading from 3.x / 4.x — breaking changes in 5.0 and the migration path |
At a glance
- Fluent CRUD that compiles to prepared statements (named parameter bag is handled internally).
- Per-driver SQL dialects (MySQL, PostgreSQL, SQLite, generic).
- Models with auto-derived schemas, configurable primary key, soft deletes, and
created_at/updated_atplumbing. - Entities with Laravel-style
getColumnAttribute()/setColumnAttribute()hooks and dirty tracking viagetOriginal(). - Transaction helper with retry attempts and a
testModeflag that always rolls back. - Query log channel that accepts a file path (with
{year}/{month}/{day}placeholders), a callable, or any object exposing acritical()method. - Server-side DataTables.js helper that handles search, sort, paging and per-column render callbacks — see docs/08-datatables.md.
Contributing
Org-wide guidelines (PSR-12, declare(strict_types=1), Conventional Commits, PHPStan + PHPUnit on every PR) live in the InitPHP .github repo:
Local checks before opening a PR:
composer qa # phpcs + phpstan + phpunit composer cs-fix # auto-format
Security
Please do not open a public issue for security vulnerabilities. The org-wide SECURITY.md describes the private disclosure channels (GitHub PVR + email).
Credits
Maintained by Muhammet ŞAFAK (info@muhammetsafak.com.tr).
License
MIT.