use strict;
use warnings;
+use base qw/DBIx::Class/;
+
=head1 NAME
DBIx::Class::Row - Basic row methods
if ($attrs) {
$new->throw("attrs must be a hashref" ) unless ref($attrs) eq 'HASH';
while (my ($k, $v) = each %{$attrs}) {
- $new->store_column($k => $v) if exists $class->_columns->{$k};
+ die "No such column $k on $class" unless $class->has_column($k);
+ $new->store_column($k => $v);
}
}
return $new;
return $self;
}
-sub ident_condition {
- my ($self) = @_;
- my %cond;
- $cond{$_} = $self->get_column($_) for keys %{$self->_primaries};
- return \%cond;
-}
-
=item delete
$obj->delete
sub get_column {
my ($self, $column) = @_;
$self->throw( "Can't fetch data as class method" ) unless ref $self;
- $self->throw( "No such column '${column}'" ) unless $self->_columns->{$column};
+ $self->throw( "No such column '${column}'" ) unless $self->has_column($column);
return $self->{_column_data}{$column}
if exists $self->{_column_data}{$column};
return undef;
=item set_columns
- my $copy = $orig->copy({ $col => $val, ... });
+ my $copy = $orig->set_columns({ $col => $val, ... });
Set more than one column value at once.
sub store_column {
my ($self, $column, $value) = @_;
$self->throw( "No such column '${column}'" )
- unless $self->_columns->{$column};
+ unless $self->has_column($column);
$self->throw( "set_column called for ${column} without value" )
if @_ < 3;
return $self->{_column_data}{$column} = $value;
my ($class, $cols, $row) = @_;
my %vals;
$vals{$cols->[$_]} = $row->[$_] for 0 .. $#$cols;
- my $new = $class->new(\%vals);
+ my $new = bless({ _column_data => \%vals }, ref $class || $class);
$new->in_storage(1);
return $new;
}