X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDBIx%2FClass%2FRow.pm;h=9f01ded7f2185a87e279c3372cee6990e6236eed;hb=484c9dda865880cd4e1cda8e0117f1d073a6aa7e;hp=cb086c8077da448834228db67ffee498d7481299;hpb=fef5d100c208d604c7a7b3c33eb6e32946d71848;p=dbsrgits%2FDBIx-Class.git diff --git a/lib/DBIx/Class/Row.pm b/lib/DBIx/Class/Row.pm index cb086c8..9f01ded 100644 --- a/lib/DBIx/Class/Row.pm +++ b/lib/DBIx/Class/Row.pm @@ -33,6 +33,7 @@ sub new { if ($attrs) { $new->throw("attrs must be a hashref" ) unless ref($attrs) eq 'HASH'; while (my ($k, $v) = each %{$attrs}) { + die "No such column $k on $class" unless exists $class->_columns->{$k}; $new->store_column($k => $v); } } @@ -104,7 +105,10 @@ UPDATE query to commit any changes to the object to the db if required. sub update { my ($self, $upd) = @_; $self->throw( "Not in database" ) unless $self->in_storage; - my %to_update = %{$upd || {}}; + if (ref $upd eq 'HASH') { + $self->$_($upd->{$_}) for keys %$upd; + } + my %to_update; $to_update{$_} = $self->get_column($_) for $self->is_changed; return -1 unless keys %to_update; my $rows = $self->storage->update($self->_table_name, \%to_update, @@ -173,6 +177,19 @@ sub get_column { return undef; } +=item get_columns + + my %data = $obj->get_columns; + +Fetch all column values at once. + +=cut + +sub get_columns { + my $self = shift; + return map { $_ => $self->get_column($_) } $self->columns; +} + =item set_column $obj->set_column($col => $val); @@ -191,6 +208,29 @@ sub set_column { return $ret; } +=item set_columns + + my $copy = $orig->set_columns({ $col => $val, ... }); + +Set more than one column value at once. + +=cut + +sub set_columns { + my ($self,$data) = @_; + while (my ($col,$val) = each %$data) { + $self->set_column($col,$val); + } +} + +=item copy + + my $copy = $orig->copy({ change => $to, ... }); + +Insert a new row with the specified changes. + +=cut + =item store_column $obj->store_column($col => $val); @@ -211,22 +251,12 @@ sub store_column { sub _row_to_object { my ($class, $cols, $row) = @_; my %vals; - foreach my $pos (0..$#$cols) { - my $c = $cols->[$pos]; - $c =~ s/^me\.//; - $vals{$c} = $row->[$pos]; - } - my $new = $class->new(\%vals); + $vals{$cols->[$_]} = $row->[$_] for 0 .. $#$cols; + my $new = bless({ _column_data => \%vals }, ref $class || $class); $new->in_storage(1); return $new; } -=item copy - - my $copy = $orig->copy({ change => $to, ... }); - -=cut - sub copy { my ($self, $changes) = @_; my $new = bless({ _column_data => { %{$self->{_column_data}}} }, ref $self);