Class::DBI::Loader::Relationship.3pm

Langue: en

Autres versions - même langue

Version: 2010-07-14 (ubuntu - 24/10/10)

Section: 3 (Bibliothèques de fonctions)

NAME

Class::DBI::Loader::Relationship - Easier relationship specification in CDBI::L

SYNOPSIS

   use Class::DBI::Loader::Relationship;
 
   my $loader = Class::DBI::Loader->new( dsn => "mysql:beerdb",
                                         namespace => "BeerDB");
 
 

Now instead of saying

     BeerDB::Brewery->has_many(beers => "BeerDB::Beer");
     BeerDB::Beer->has_a(brewery => "BeerDB::Brewery");
 
     BeerDB::Handpump->has_a(beer => "BeerDB::Beer"); 
     BeerDB::Handpump->has_a(pub => "BeerDB::Pub");
     BeerDB::Pub->has_many(beers => [ BeerDB::Handpump => 'beer' ]);
     BeerDB::Beer->has_many(pubs => [ BeerDB::Handpump => 'pub' ]);
 
 

Just say

     $loader->relationship( "a brewery produces beers" );
     $loader->relationship( "a pub has beers on handpumps" );
 
 

DESCRIPTION

This module acts as a mix-in, adding the "relationship" method to "Class::DBI::Loader". Since "Class::DBI::Loader" knows how to map between table names and class names, there ought to be no need to replicate the names.

In addition, it is common (but not universal) to want reverse relationships defined for has-many relationships, and for has-a relationships to be defined for the linkages surrounding a many-to-many table.

The aim of "CDBIL::Relationship" is to simplify the declaration of common database relationships by providing both of these features.

The "relationship" takes a string. It recognises table names (singular or plural, for convenience) and extracts them from the ``sentence''.

AUTHOR

Simon Cozens, "simon@cpan.org"

SEE ALSO

Class::DBI::Loader.