NAME

Prty::ModelCache - Verwaltung/Caching von Modell-Objekten

BASE CLASS

Prty::Hash

SYNOPSIS

Instanziiere das Modell-Objekt für eine Reihe von Tabellen:

$mod = Prty::ModelCache->new($db,@types);

Liefere alle Datensätze einer Tabelle:

@rows|$tab = $mod->all($type);

Liefere Datensatz zu Primärschlüssel:

$row = $mod->lookup($type,$id);

Liefere zu einem Datensatz alle Kind-Datensätze einer Kind-Tabelle:

@rows|$tab = $mod->childs($row,$childType);

Liefere zu einem Datensatz den Eltern-Datensatz einer Eltern-Tabelle:

$row = $mod->parent($row,$parentType);

DESCRIPTION

Ein Objekt der Klasse stellt einen Cache für eine Reihe von Tabellen/Views einer Datenbank dar. Mit den Methoden der Klasse kann über die Datensätze navigiert werden, wobei diese sukzessive geladen werden. Tabellen, deren Inhalt nicht zugegriffen wird, werden auch nicht geladen.

Da eine Tabelle/View beim ersten Zugriff vollständig geladen wird, ist die Klasse nicht für Tabellen mit Massendaten geeignet.

Die Klasse beruht auf einer speziellen Datenbank-Klasse, die aktuell nicht Teil der Prty-Bibliothek ist. Die Klassen-Logik ist jedoch allgemeingültig und kann auf beliebige externe Repräsentationen übertragen werden.

EXAMPLES

  • Telefonliste

Tabellen:

Person  Telefon
------  -------
id      id
name    person_id
        nummer

Programm:

my $mod = Prty::ModelCache->new($db,
    'person',
    'telefon',
);

for my $per ($mod->all('person')) {
    printf "%s\n",$per->name;
    for my $tel ($mod->childs($per,'telefon')) {
        printf "  %s\n",$tel->nummer;
    }
}
__END__
Frank Seitz
  0176/78243503
  • Kolumnen mit Präfix

Tabellen:

Person    Telefon
------    -------
per_id    tel_id
per_name  tel_person_id
          tel_nummer

Programm:

my $mod = Prty::ModelCache->new($db,
    [person=>'per'],
    [telefon=>'tel'],
);

for my $per ($mod->all('person')) {
    printf "%s\n",$per->per_name;
    for my $tel ($mod->childs($per,'telefon')) {
        printf "  %s\n",$tel->tel_nummer;
    }
}
__END__
Frank Seitz
  0176/78243503

METHODS

Konstruktor

new() - Konstruktor

Synopsis

$mod = $class->new($db,@types);

Description

Instanziiere einen Cache für Modell-Objekte @types der Datenbank $db und liefere eine Referenz auf dieses Objekt zurück.

all() - Entitätsmenge

Synopsis

@rows|$tab = $mod->all($type);

Description

Liefere alle Datensätze vom Typ $type. Im Skalarkontext liefere ein Tabellenobjekt mit den Datensätzen.

lookup() - Datensatz zu Schlüsselwert

Synopsis

$ent = $mod->lookup($type,$id);

Description

Ermittele in der Tabelle $type den Datensatz mit dem Schlüsselwert $id und liefere diesen zurück. Existiert kein Datensatz mit dem Schlüsselwert $id, wird eine Exception geworfen.

childs() - Kind-Datensätze eines Datensatzes

Synopsis

@rows|$tab = $mod->childs($row,$childType);

Description

Ermittele zu Datensatz $row alle Kind-Datensätze vom Typ $childType und liefere diese zurück. Im Skalarkontext liefere ein Tabellenobjekt mit diesen Datensätzen.

parent() - Eltern-Datensatz eines Datensatzes

Synopsis

$par = $mod->parent($row,$parentType);

Description

Liefere zu Datensatz $row dessen Eltern-Datensatz vom Typ $parentType.

Kolumnen

pk() - Name Primärschlüsselkolumne

Synopsis

$pk = $mod->pk($type);

Description

Liefere den Namen der Primärschlüsselkolumne des Modell-Objekts $type. Ohne vereinbarten Kolumnenpräfix lautet der Name

id

Mit vereinbarten Kolumnenpräfix lautet der Name

<prefix>_id

fk() - Name Fremdschlüsselkolumne

Synopsis

$fk = $mod->fk($type,$parentType);

Description

Liefere den Namen der Fremdschlüsselkolumne eines Modell-Objekts vom Typ $type für ein Parent-Modell-Objekt vom Typ $parentType.

Ohne vereinbarten Kolumnenpräfix für $type lautet der Name

<parentType>_id

Mit vereinbarten Kolumnenpräfix für $type lautet der Name

<prefix>_<parentType>_id

AUTHOR

Frank Seitz, http://fseitz.de/