aeatech / transaction-manager-common-transactions
Contains reusable, dialect-independent SQL transaction implementations, identifier quoting abstraction, and shared builders used across MySQL, PostgreSQL, and future AEATech Transaction Manager adapters
Installs: 24
Dependents: 2
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/aeatech/transaction-manager-common-transactions
Requires
- php: >=8.2
- ext-pdo: *
- aeatech/transaction-manager-core: ^1.0
Requires (Dev)
- mockery/mockery: ^1.6.10
- phpstan/phpstan: ^2.1
- phpstan/phpstan-mockery: ^2.0
- phpunit/phpunit: ^11.5
- roave/security-advisories: dev-master
This package is not auto-updated.
Last update: 2026-01-12 10:15:43 UTC
README
This package contains dialect-agnostic SQL transaction implementations shared across different database adapters of the AEATech Transaction Manager ecosystem.
It provides a unified, reusable foundation for SQL write-operations that work with any relational database as long as a database-specific identifier quoter is supplied.
Typical adapters are built on top of this package:
aeatech/transaction-manager-mysqlaeatech/transaction-manager-postgresql
This package does not contain any dialect-specific SQL features
(e.g., INSERT IGNORE, ON DUPLICATE KEY, ON CONFLICT).
Those features belong to adapter-specific packages.
โจ Features
- Common SQL transaction types:
InsertTransactionUpdateTransactionDeleteTransactionUpdateWhenThenTransaction(multi-row conditional updates)SqlTransaction(raw SQL)
- Fully decoupled from any SQL dialect
- Requires an implementation of
IdentifierQuoterInterface- MySQL โ backtick quoter\
- PostgreSQL โ double-quote quoter\
- Compatible with Transaction Manager Core retry policy, backoff strategy, and transactional engine
- Cleanly testable in isolation
๐ฆ Installation
composer require aeatech/transaction-manager-common-transactions
๐งฉ Architecture Overview
Each transaction class builds SQL using:
- an injected identifier quoter, and\
- a dedicated builder (e.g.,
InsertValuesBuilder,UpdateWhenThenDefinitionsBuilder)
All SQL dialect specifics are delegated to adapter packages.
transaction-manager-core
โ
โ
transaction-manager-common-transactions
โ
โโโโโโโโโ transaction-manager-mysql
โโโโโโโโโ transaction-manager-postgresql
๐ง Usage Example
use AEATech\TransactionManager\Transaction\InsertTransaction; use AEATech\TransactionManager\MySQL\IdentifierQuoter; use AEATech\TransactionManager\Transaction\Internal\InsertValuesBuilder; $transaction = new InsertTransaction( insertValuesBuilder: new InsertValuesBuilder(), quoter: new IdentifierQuoter(), tableName: 'users', rows: [ ['name' => 'Alex', 'age' => 30], ['name' => 'Bob', 'age' => 25], ], columnTypes: ['name' => \PDO::PARAM_STR, 'age' => \PDO::PARAM_INT], );
๐งช Running Tests in Docker
Start containers
docker-compose -p aeatech-transaction-manager-common-transactions -f docker/docker-compose.yml up -d --build
Stop and remove containers
docker-compose -p aeatech-transaction-manager-common-transactions -f docker/docker-compose.yml down -v
๐ฅ Install dependencies (example: PHP 8.2)
docker-compose -p aeatech-transaction-manager-common-transactions -f docker/docker-compose.yml exec php-cli-8.2 composer install
โถ๏ธ Run tests for a specific PHP version
PHP 8.2:
docker-compose -p aeatech-transaction-manager-common-transactions -f docker/docker-compose.yml exec php-cli-8.2 vendor/bin/phpunit
PHP 8.3:
docker-compose -p aeatech-transaction-manager-common-transactions -f docker/docker-compose.yml exec php-cli-8.3 vendor/bin/phpunit
PHP 8.4:
docker-compose -p aeatech-transaction-manager-common-transactions -f docker/docker-compose.yml exec php-cli-8.4 vendor/bin/phpunit
๐ Run all configured PHP variants
for v in 8.2 8.3 8.4 ; do \ echo "Testing PHP $v..."; \ docker-compose -p aeatech-transaction-manager-common-transactions -f docker/docker-compose.yml exec -T php-cli-$v vendor/bin/phpunit || break; \ done
Run phpstan
docker-compose -p aeatech-transaction-manager-common-transactions -f docker/docker-compose.yml exec php-cli-8.4 vendor/bin/phpstan analyse -c phpstan.neon --memory-limit=1G
๐งต Attach interactive shells
PHP 8.2:
docker-compose -p aeatech-transaction-manager-common-transactions -f docker/docker-compose.yml exec php-cli-8.2 /bin/bash
PHP 8.3:
docker-compose -p aeatech-transaction-manager-common-transactions -f docker/docker-compose.yml exec php-cli-8.3 /bin/bash
PHP 8.4:
docker-compose -p aeatech-transaction-manager-common-transactions -f docker/docker-compose.yml exec php-cli-8.4 /bin/bash
License
This project is licensed under the MIT License. See the LICENSE file for details.