}
sub _ident_values {
- my ($self) = @_;
+ my ($self, $use_storage_state) = @_;
my (@ids, @missing);
for ($self->_pri_cols) {
- push @ids, exists $self->{_column_data_in_storage}{$_}
+ push @ids, ($use_storage_state and exists $self->{_column_data_in_storage}{$_})
? $self->{_column_data_in_storage}{$_}
: $self->get_column($_)
;
=cut
sub ident_condition {
- my ($self, $alias) = @_;
+ shift->_mk_ident_cond(@_);
+}
+
+sub _storage_ident_condition {
+ shift->_mk_ident_cond(shift, 1);
+}
+
+sub _mk_ident_cond {
+ my ($self, $alias, $use_storage_state) = @_;
my @pks = $self->_pri_cols;
- my @vals = $self->_ident_values;
+ my @vals = $self->_ident_values($use_storage_state);
my (%cond, @undef);
my $prefix = defined $alias ? $alias.'.' : '';