Oryx
view release on metacpan or search on metacpan
lib/Oryx/DBI/Association/Array.pm view on Meta::CPAN
$sth = $obj->dbh->prepare($stmnt);
while (my ($index, $thing) = each %{tied(@$value)->deleted}) {
$lt_where{$lt_flds[2]} = $index;
@bind = $sql->values(\%lt_where);
$sth->execute(@bind);
}
$sth->finish;
tied(@$value)->deleted({});
}
if (%{tied(@$value)->created}) {
@lt_fieldvals{@lt_flds} = ($obj->id, '', '');
$stmnt = $sql->insert($lt_name, \%lt_fieldvals);
$sth = $obj->dbh->prepare($stmnt);
while (my ($index, $thing) = each %{tied(@$value)->created}) {
$lt_fieldvals{$lt_flds[1]} = defined $thing ? $thing->{id} : undef;
$lt_fieldvals{$lt_flds[2]} = $index;
@bind = $sql->values(\%lt_fieldvals);
$sth->execute(@bind);
}
$sth->finish;
tied(@$value)->created({});
}
if (%{tied(@$value)->updated}) {
%lt_where = ( $lt_flds[0] => $obj->id, $lt_flds[2] => '' );
%lt_fieldvals = ( $lt_flds[1] => '' );
$stmnt = $sql->update($lt_name, \%lt_fieldvals, \%lt_where);
$sth = $obj->dbh->prepare($stmnt);
while (my ($index, $thing) = each %{tied(@$value)->updated}) {
$lt_fieldvals{$lt_flds[1]} = defined $thing ? $thing->{id} : undef;
$lt_where{$lt_flds[2]} = $index;
@bind = $sql->values(\%lt_fieldvals);
push @bind, $sql->values(\%lt_where);
$sth->execute(@bind);
}
$sth->finish;
tied(@$value)->updated({});
}
$self->update_backrefs($obj, @$value);
$obj->dbh->commit;
}
sub delete {
my $self = shift;
my ($query, $obj) = @_;
my $accessor = $self->role;
my $value = $obj->$accessor;
if ($self->constraint eq 'Composition') {
# cascade the delete
while (my $thing = pop @$value) {
$thing->delete;
}
} elsif ($self->constraint eq 'Aggregation') {
# just clear the Array
@$value = ();
}
$self->update(@_);
}
sub search {
my ($self, $query) = @_;
}
sub construct {
my ($self, $obj) = @_;
my $assoc_name = $self->role;
my @args = ($self, $obj);
my @list;
if ($obj->{$assoc_name}) {
@list = @{$obj->{$assoc_name}};
}
$obj->{$assoc_name} = [ ] unless $obj->{$assoc_name};
tie @{$obj->{$assoc_name}}, __PACKAGE__, @args;
if (@list) {
my $i = 0;
grep { tied(@{$obj->{$assoc_name}})->_set_created($i++, $_) } @list;
my $tieobj = tied(@{$obj->{$assoc_name}});
my $sql = SQL::Abstract->new;
my $lt_name = $self->link_table;
my @lt_flds = $self->link_fields;
my %lt_where = ($lt_flds[0] => $obj->id);
my $stmnt = $sql->delete($lt_name, \%lt_where);
my $sth = $obj->dbh->prepare($stmnt);
my @bind = $sql->values(\%lt_where);
$sth->execute(@bind);
$sth->finish;
$tieobj->deleted({});
$tieobj->updated({});
}
}
# Fill an array ref with ids from the link table and order by 'meta'.
# The ids are each tied to a Reference value type which will retrieve
# the referenced object (lazy loading)
sub load {
my ($self, $owner) = @_;
my $lt_name = $self->link_table;
my ($s_id_field, $t_id_field, $meta_field) = $self->link_fields;
my (@fields, %where, @order);
@fields = ($t_id_field, '_seq');
( run in 0.658 second using v1.01-cache-2.11-cpan-0bb4e1dffa6 )