RoPkg::DBObject(3) General pourpose database object.

VERSION

0.1.4

DESCRIPTION

This class can be used as a base class for objects who holds all their information in a database. The class provides the base methods to add/delete/update/select the object to/from a database.

RoPkg::DBObject inherits RoPkg::Object .

SYNOPSIS


package RoPkg::Person;
use strict;
use warnings;
use RoPkg::DBObject;
use RoPkg::Exceptions;

use vars qw($VERSION @ISA);
@ISA=qw(RoPkg::DBObject);
my $methods = {
id => '-',
Name => '-',
Addr => '-',
};
sub new {
my ($class, %opt) = @_;
my $self;
$opt{methods} = $methods;
$self = $class->SUPER::new(%opt);
return $self;
}
sub AddToDB {
my ($self) = @_;
OutsideClass->throw('Called from outside class')
if ( !$self or ref($self) ne $CLASS);
return $self->SQL_Insert();
}
1;
tester.pl
use warnings;
use strict;
use RoPkg::Person;
use RoPkg::DB;
sub main {
my ($p, $db);

$db = new RoPkg::DB();
$db->add('dsn...', 'user', 'pass', 'dbc');
$p = new RoPkg::Person(dbo => $db, dbo_method => 'db_dbc');
$p->id(1);
$p->Name('John Doe');
$p->Addr('home');
$p->AddToDB();
}
main();

SUBROUTINES/METHODS

new($hashref)

Constructor of the class. At this moment new() accepts 3 parameters:
*) dbo
*) dbo_method
*) quote_char

dbo and dbo_method must be given to the constructor. quote_char is optional. dbo is the database object (a instance of RoPkg::DB)and dbo_method dbo_method is the name of the method used to have access to the database handle. quote_char is the char used internally by DBI to quote the table names, field names and so on. Default, the quote_char is empty (no quotation). If you are using PostgreSQL and you have upcase chars in table and fields names use quote_char => q{"} .

Exceptions:

RoPkg::DBObject uses the exceptions provided by RoPkg::Exceptions. new() throws the following exceptions:

*) Param::Mising
*) Param::Wrong

Param::Missing is raised when dbo or dbo_method parameters have not been specified in the parameters list.

Param::Wrong is raised when dbo or dbo_method parameters are not defined (or empty).

dbo($dbo)

get/set method. If $dbo is present (and defined), the internal $dbo object will be replaced with the new one. If $dbo is not present, the method acts as a get method, and will return the database object. The method will raise OutsideClass exception if is called outside the class instance.

dbo_method($dbo_method)

get/set method. If $dbo_method is present (and defined), the internal $dbo_method value will be replaced with the one specified by $dbo_method parameter. Otherwise, the get behaviour will be selected, and the method will return the current value of $dbo_method. The method will raise OutsideClass exception if is called outside the class instance.

dbh()

Returns the DBI object used by this object.

SQL METHODS

The following methods are responsable for all operations involving the database. All methods use SQL::Abstract to generate sql queries to ensure portability of the queries.

The data that will be added/deleted to the database, is taken from the methods provided by $methods .

SQL_Insert()

add the current object to the database. Returns the value of DBI->execute.

SQL_Update(@fields)

update the data from database. The fields array hold all the field names who will uniquely identify the object in the database (usually the id of the object).

SQL_Delete(@fields)

update the data from database. The fields array hold all the field names who will uniquely identify the object in the database (usually the id of the object).

SQL_Select(@fields)

searches into the database for the object and initialize the current object with the values found. The fields array hold all the field names who will uniquely identify the object in the database (usually the id of the object). This method is special. It will look only at the first record who meet the requirements (in sql 'LIMIT 1'). Also, if no records are found DB::NoResults exception is raised.

DEPENDENCIES

RoPkg::Object require perl 5.008 or later and the following modules:
SQL::Abstract
RoPkg::Object
RoPkg::Exceptions

PERL CRITIC

The code is perl critic level 2 compliant and almost level 1 compliant

DIAGNOSTICS

This module comes with his own tests. To run the tests unpack the source, and use 'make test' command.

CONFIGURATION AND ENVIRONMENT

This module does not use any configuration files or environment variables. The dependencies however can use them. Please read the man page of each dependency to be sure.

INCOMPATIBILITIES

Do not install this version on the same machine with Simba <= 0.7.1

BUGS AND LIMITATIONS

None known to the author

AUTHOR

Subredu Manuel <[email protected]>

LICENSE AND COPYRIGHT

Copyright (C) 2005 Subredu Manuel. All Rights Reserved. This module is free software; you can redistribute it and/or modify it under the same terms as Perl itself. The LICENSE file contains the full text of the license.