return (map { $self->{_column_data}{$_} } keys %{$self->_primaries});
}
-sub set_primary {
+sub set_primary_key {
my ($class, @cols) = @_;
my %pri;
$pri{$_} = {} for @cols;
my $query;
if (ref $vals[0] eq 'HASH') {
$query = $vals[0];
- } elsif (@pk == 1 && @vals == 1) {
- return ($class->retrieve_from_sql($class->_ident_cond, $vals[0]))[0];
+ } elsif (@pk == @vals) {
+ my $ret = ($class->retrieve_from_sql($class->_ident_cond, @vals))[0];
+ #warn "$class: ".join(', ', %{$ret->{_column_data}});
+ return $ret;
} else {
$query = {@vals};
}
die "Can't retrieve unless all primary keys are specified"
unless (keys %$query >= @pk); # If we check 'em we run afoul of uc/lc
# column names etc. Not sure what to do yet
- return ($class->search($query))[0];
+ my $ret = ($class->search($query))[0];
+ #warn "$class: ".join(', ', %{$ret->{_column_data}});
+ return $ret;
+}
+
+sub discard_changes {
+ my ($self) = @_;
+ delete $self->{_dirty_columns};
+ $_[0] = $self->retrieve($self->id);
}
1;