boxphp/database
Composer 安装命令:
composer require boxphp/database
包简介
BoxPHP Database - PDO Connection, QueryBuilder, Pool
README 文档
README
BoxPHP 数据库包 - PDO 连接、查询构建器及连接池
安装
composer require boxphp/database
使用
PDO 连接
use BoxPHP\Database\Database\PdoConnection; $db = new PdoConnection([ 'driver' => 'mysql', 'host' => '127.0.0.1', 'port' => 3306, 'database' => 'myapp', 'username' => 'root', 'password' => '', ]); $db->connect(); $users = $db->select('SELECT * FROM users WHERE id = ?', [1]);
查询构建器
use BoxPHP\Database\Database\QueryBuilder; // SELECT $users = (new QueryBuilder('users')) ->select('id', 'name', 'email') ->where('status', 'active') ->orderBy('created_at', 'DESC') ->limit(10) ->get(); // INSERT $id = (new QueryBuilder('users')) ->insert(['name' => 'John', 'email' => 'john@example.com']); // UPDATE =count = (new QueryBuilder('users')) ->where('id', 1) ->update(['status' => 'inactive']); // DELETE =count = (new QueryBuilder('users')) ->where('id', 1) ->delete(); // 聚合 $count = (new QueryBuilder('users')) ->where('status', 'active') ->count(); $sum = (new QueryBuilder('orders')) ->where('user_id', 1) ->sum('amount');
连接池
use BoxPHP\Database\Database\DatabasePool; $pool = new DatabasePool([ 'driver' => 'mysql', 'host' => '127.0.0.1', 'database' => 'myapp', 'username' => 'root', 'password' => '', 'pool_max_size' => 10, ]); $db = $pool->get(); $users = $db->select('SELECT * FROM users'); $pool->put($db);
事务
$db->beginTransaction(); try { $db->execute('UPDATE accounts SET balance = balance - ? WHERE id = ?', [100, 1]); $db->execute('UPDATE accounts SET balance = balance + ? WHERE id = ?', [100, 2]); $db->commit(); } catch (\Exception $e) { $db->rollBack(); throw $e; }
依赖
- PHP >= 8.1
- boxphp/core ^1.0
- PDO 扩展
统计信息
- 总下载量: 0
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 3
- 依赖项目数: 1
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2026-06-27