Activator
view release on metacpan or search on metacpan
lib/Activator/DB.pm view on Meta::CPAN
=item *
Get data from a different db for a while:
$db->connect('alt'); # connect to alternate db
# do something
$db->connect('def'); # reset to default connection
# do something else
=item *
Transactions (NOT YET IMPLEMENTED)::
my $altdb = Activator::DB->connect('altdb');
$db->begin_work();
$db->do( @stuff );
$db->do( @more_stuff );
$db->commit();
=back
=head1 DESCRIPTION
C<Activator::DB> module provides convenience and total consistency to
accessing a database throughout a project. The idea is to reduce
typing for the common cases, and remove worrying about connections.
This module is a wrapper for DBI providing these advantages:
=over
=item *
Provides connect string aliases centrally configured.
=item *
Provide consistent arguments handling to all query functions.
=item *
Provides connection caching without Apache::DBI -- this allows use of
your model layer code in crons, daemons AND website.
=item *
Connection and query debug dumps using your project or module level
C<Activator::Log> config, or on a per-query basis.
=item *
Allows all code in your project/team/company to access the db in a
consistent fashion.
=item *
By default, dies on all errors enforcing try/catch programming
=item *
Implemented as a singleton so each process is guranteed to be using no
more than one connection to each database from the pool.
=back
Disadvantages:
=over
=item *
If you know DBI, you don't necessarily know C<Activator::DB>
=item *
NOT THREAD SAFE
=item *
Only tested with MySql and PostgreSQL
=back
=head1 CONFIGURATION
This module uses L<Activator::Registry> to automatically choose default
databases, and L<Activator::Log> to log warnings and errors.
=head2 Registry Setup (from Activator::Registry)
This module expects an environment variable ACT_REG_YAML_FILE to be
set. If you are utilizing this module from apache, this directive must
be in your httpd configuration:
SetEnv ACT_REG_YAML_FILE '/path/to/config.yml'
If you are using this module from a script, you need to insure that
the environment is properly set using a BEGIN block:
BEGIN{
$ENV{ACT_REG_YAML_FILE} ||= '/path/to/config.yml'
}
=head2 Registry Configuration
Add an C<Activator::DB> section to your project YAML configuration file:
'Activator::Registry':
log4perl<.conf>: # Log4perl config file or definition
# See Logging Configuration below
'Activator::DB':
default: # default configuration for all connections
connection: <conn_alias>
## Optional default attributes and config for all connections
config:
debug: 0/1 # default: 0, affects all queries, all aliases
reconn_att: <int> # attempt reconnects this many times. default: 3
reconn_sleep: <int> # initial sleep seconds between reconnect attempts.
# doubles every attempt. default: 1
attr: # connection attributes. Only AutoCommit at this time
( run in 0.595 second using v1.01-cache-2.11-cpan-39bf76dae61 )