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

1.0.0 2026-01-11 12:01 UTC

This package is not auto-updated.

Last update: 2026-01-12 10:15:43 UTC


README

Code Coverage

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-mysql
  • aeatech/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:
    • InsertTransaction
    • UpdateTransaction
    • DeleteTransaction
    • UpdateWhenThenTransaction (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.