NAME
XAS::Model::Database - Define the database schema used by the XAS environment
SYNOPSIS
use XAS::Model::Database 'Nmon';
try {
$schema = XAS::Model::Database->opendb('database');
my @rows = Master->search($schema);
foreach my $row (@rows) {
printf("Hostname = %s\n", $row->Hostname);
}
} catch {
my $ex = $_;
print $ex;
};
DESCRIPTION
This modules loads the necessary table definations for the XAS environment. It also exports symbols that allows the shortcut methods from XAS::Model::DBM to work. Please see EXPORT for those variables. This module can be loaded in several differant ways.
Example
use XAS::Model::Database 'Master';
or
use XAS::Model::Database qw( Master Detail );
or
use XAS::Model::Database ':all';
The difference is that in the first example you are only loading the "Master" symbol into your module. The second example loads the symbols "Master" and "Detail". The "all" qualifer would export all defined symbols.
METHODS
opendb($database)
This method provides the defaults necessary to call the DBIx::Class::Schema connect() method. It takes one parameter.
- $database
-
The name of a configuration item suitable for DBIx::Class::Schema::Configure.
Example
my $handle = XAS::Model::Database->opendb('database');
EXPORT
Symbols for the tables are exported in this fashion. The rule is that any class below the "XAS::Model::Database" hierarchy will be joined and camel cased to signify that they are constants.
For example "XAS::Model::Database::Alert" defines a table structure within the database. The exported symbol would be "Alert". These exported symbols are shortcuts. It is easier to write "Alert->find" then "XAS::Model::Database::Alert->find".
SEE ALSO
DBIx::Class
AUTHOR
Kevin Esteb, <kevin@kesteb.usg>
COPYRIGHT AND LICENSE
Copyright (C) 2012 by Kevin L. Esteb
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself, either Perl version 5.8.8 or, at your option, any later version of Perl 5 you may have available.