kickpeach / database
a database component
Installs: 26
Dependents: 1
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
pkg:composer/kickpeach/database
Requires
- php: >=7.1.3
Requires (Dev)
- phpunit/phpunit: ^5.4
This package is not auto-updated.
Last update: 2025-10-24 15:30:57 UTC
README
基于PDO的kickpeach框架的databbase组件,亦可以独立使用,支持MySQl以及PostgreSQL数据库
怎么使用
安装
composer require kickpeach/database -vvv
使用
具体使用,可参考tests
get connection
- MySql
$dsn = sprintf('mysql:host=%s;port=%s;dbname=%s;charset=%s', '127.0.0.1', 3306, 'es_demo', 'utf8mb4');
$conn = new MySqlConnection($dsn, 'root', 123123);
- Postgres
$dsn = sprintf('pgsql:host=%s;port=%s;dbname=%s', '127.0.0.1', 3306, 'es_demo');
$conn = new PostgresConnection($dsn, 'root', 123123);
insert and get insert id
$insertId = $conn->table('profile')->insertGetId([
    'name'      => 'test-name',
    'gender'    => 1,
    'birthday'  => '1988-12-01 01:00:01', //DATETIME
    'memo'      => 'this is a test memo',
    'lat'       => '30.54916000', //DECIMAL(10,8)
    'lng'       => '104.06761000' //DECIMAL(11,8)
]);
insert and get the number of rows affected
$affectNum = $conn->table('profile')->insert([
    [
        'name'      => 'test-name',
        'gender'    => 1,
        'birthday'  => '1988-12-01 01:00:01',
        'memo'      => 'this is a test memo',
        'lat'       => '30.54916000',
        'lng'       => '104.06761000'
    ],
    [
        'name'      => 'test-name-1',
        'gender'    => 1,
        'birthday'  => '2010-12-01 01:00:01',
        'memo'      => 'this is another test memo',
        'lat'       => '30.54916000',
        'lng'       => '104.06761000'
    ],
]);
update and get the number of rows affected
affectNum = $conn->update('update profile set name = :name, memo = :memo where id = :id', [
    ':name'     => 'test-name',
    ':memo'     => 'this is another memo',
    ':id'       => $id,
]);
select
$records = $conn->select('select * from profile where id = :id', [
    ':id'   => $id,
]);
delete and get the number of rows affected
$affectNum = $conn->delete('delete from profile where id = :id', [
    ':id'       => $id,
]);
transaction
$conn->transaction(function ($conn) {
    //do something...
});
get query logs
$queryLogs = $conn->getQueryLog();
execute the given callback in "dry run"(空转) mode
$conn->pretend(function ($conn) {
    //do something...
});