NAME
Rose::Planter::DB -- base db class for Rose-Planter planted objects.
DESCRIPTION
This is derived from Rose::DB, but adds a few class methods as described below. Also, it allows database to be registered based on configuration files.
METHODS
- DateTime::Duration::TO_JSON
-
This is defined here to serialize durations as postgres intervals.
- dbi_connect
-
Connect and retain the db handle. Also, set the time zone to UTC.
- release_dbh
-
Overridden to hold onto dbh's.
- register_databases
-
Register all the rose databases for this class.
Arguments :
module_name: The name of the perl module for which we are registering databases. This will be used to check for an environment variable named (uc $module_name)."_LIVE" to see if the live database configuration should be used. Also, if a unit test suite is running, the current Module::Build object will indicate that this module is being tested and hence a test database should be used.
register_params: A hash of parameters to be sent verbatim to Rose::DB::register_db.
conf: a configuration object which will be queried as follows :
$conf->db : parameters for the database.
This should return a hash with keys such as "database", "schema", and "host" which correspond to the parameters sent to Rose::DB::register_db.
The "test" database will be determined using information from Module::Build::Database. When HARNESS_ACTIVE is true, conf should not be passed.
- registered_by
-
Given a module name, return the name of the Rose::DB-derived class which called register_databases.
- load_golden
-
Load a golden dataset into the database.
- has_primary_key [ TABLE | PARAMS ]
-
Just like the overridden method in Rose::DB.pm except that it ignores database objects that begin with 'v_'. This provides a naming convention to avoid warnings for missing keys when loading views.
- do_sql
-
Do some sql and return the result as an arrayref of hashrefs.