1 package DBIx::Data::Store::CRUD;
7 bless({ %{$_[0]} }, ref($proto)||$proto);
10 sub _sql { shift->{sql} }
11 sub _raw { shift->{raw} }
15 my ($run_type, $sql_type, @args) = @_;
16 my $sql = $self->_sql->{$sql_type}||die "No such sql type ${sql_type}";
17 $self->_raw->${\"run_${run_type}"}($sql, @args);
20 sub flatten { @{shift->_run('rowset', 'select_all', @_)} }
22 sub to_stream { shift->_run('rowstream', 'select_all', @_) }
24 sub clear { shift->_run('row','delete_all',@_) }
26 sub get { shift->_run('row','select_one',@_) }
30 $self->_run('row','update_one', [ @{$_[1]}, @{$_[0]} ]);
33 sub add { shift->_run('row','insert_one',@_) }
34 sub remove { shift->_run('row','delete_one',@_) }