AnyDataset-DB provides a relational database abstraction layer. It is part of the Anydataset project, an agnostic data source abstraction layer for PHP.
Learn more about Anydataset here.
- Connection based on URI
- Handles compatibility and code optimization across multiple databases (e.g., MySQL, PostgreSQL, MS SQL Server)
- Built-in Query Cache support using a PSR-6 compliant interface
- Enables connection routing based on regular expressions for queries (e.g., directing queries to different databases for specific tables)
Database connections are defined using URL-based connection strings.
Supported drivers are listed below:
Database | Connection String | Factory Method |
---|---|---|
SQLite | sqlite:///path/to/file | getDbRelationalInstance() |
MySQL/MariaDB | mysql://username:password@hostname:port/database | getDbRelationalInstance() |
PostgreSQL | psql://username:password@hostname:port/database | getDbRelationalInstance() |
SQL Server (DbLib) | dblib://username:password@hostname:port/database | getDbRelationalInstance() |
SQL Server (Sqlsrv) | sqlsrv://username:password@hostname:port/database | getDbRelationalInstance() |
Oracle (OCI8) | oci8://username:password@hostname:port/database | getDbRelationalInstance() |
Generic PDO | pdo://username:password@pdo_driver?PDO_PARAMETERS | getDbRelationalInstance() |
Example usage:
<?php
$conn = \ByJG\AnyDataset\Db\Factory::getDbInstance("mysql://root:[email protected]/myschema");
- Getting Started
- Basic Query and Update
- Sql Statement Object
- Cache results
- Database Transaction
- Load Balance and Connection Pooling
- Database Helper
- Filtering the Query
- Passing Parameters to PDODriver
- Generic PDO Driver
- Running Tests
- Getting an Iterator from an existing PDO Statament
- Pre Fetch records
Just type:
composer require "byjg/anydataset"
flowchart TD
byjg/anydataset-db --> byjg/anydataset-array
byjg/anydataset-db --> ext-pdo
byjg/anydataset-db --> byjg/uri
byjg/anydataset-db --> psr/cache
byjg/anydataset-db --> psr/log