NAME

DBIx::TransactionManager::Extended - extended DBIx::TransactionManager

SYNOPSIS

use DBI;
use DBIx::TransactionManager::Extended;

my $dbh = DBI->connect('dbi:SQLite:');
my $tm = DBIx::TransactionManager::Extended->new($dbh);

# begin transaction
$tm->txn_begin;

    # execute query
    $dbh->do("insert into foo (id, var) values (1,'baz')");
    # And you can do multiple database operations here

    for my $data (@data) {
        push @{ $txn->context_data->{data} } => $data;
        $tm->add_hook_after_commit(sub {
            my $context_data = shift; # with the current (global) transaction
            my @data = @{ $context_data->{data} };
            return unless @data;

            ...

            $context_data->{data} = [];
        });
    }

# and commit it.
$tm->txn_commit;

DESCRIPTION

DBIx::TransactionManager::Extended is extended DBIx::TransactionManager. This module provides some useful methods for application development.

EXTENDED METHODS

context_data

This is a accessor for a context data. The context data is a associative array about a current transaction's context data.

add_hook_before_commit

Adds hook that run at before the commit all transactions.

add_hook_after_commit

Adds hook that run at after the commit all transactions.

remove_hook_before_commit

Removes hook that run at before the commit all transactions.

remove_hook_after_commit

Removes hook that run at after the commit all transactions.

SEE ALSO

DBIx::TransactionManager

LICENSE

Copyright (C) karupanerura.

This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.

AUTHOR

karupanerura <karupa@cpan.org>