NAME

DBSchema::Sample - Sample schema including all common relations

SYNOPSIS

#=====================================================================
# DECLARATIONS
#=====================================================================
use strict;
use DBSchema::Sample;

my $dbh = dbh();
my $sql = DBSchema::Sample->sql;

#=====================================================================
#  PROGRAM PROPER
#=====================================================================


for (@$sql) {
    warn $_;
    $dbh->do($_); 
}


#=====================================================================
#  SUBROUTINES
#=====================================================================

#
# modify for your method of getting $dbh (DBI database handles)
#

sub dbh {
    use DBIx::Connect;

    my $dbh = DBIx::Connect->to('horse1_test');

}

DESCRIPTION

This creates the database schema discussed in "The Practical SQL Handbook by Bowman, Emerson and Darnovsky" (Addison-Wesley). It is useful to have something like this when you want to play around with a DBI wrapper (or 12) but don't feel like creating a realistic schema and populating it with sensible data.

Tested on MySQL 4.0.14. Subclasses for other databases welcome.

PREREQUISITES

It is assumed that you have done a

CREATE DATABASE db_name

And that the $dbh that you use will be connecting to that created database.

This almost goes without saying, but it never helps to be complete.

EXPORT

None by default.

SCHEMA DESCRIPTON

authors =1:n=> titleauthors

titles =1:n=> titleauthors

Therefore authors =n:n=> titles

titles =1:n=> titleditors

editors =1:n=> titleditors

Therefore editors =n:n=> titles

titles =1:n=> roysched

At first, I didn't understand how a title could have more than one royalty, then I realized that a title has varying royalties based on the total volume sold.

publishers =1:n=> titles

titles =1:n=> salesdetails

sales =1:n=> salesdetails

AUTHOR

T. M. Brannon, tbone@cpan.org

SEE ALSO

perl.