X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDBIx%2FClass%2FPK%2FAuto.pm;h=523ec27035f3f31ac2011003e6fb15fdeba3014f;hb=9aae35666a35bad290f55e574d053a074c1d6757;hp=64c8c8315d22145fc552a295134870a3db8e4045;hpb=fefe28169210318416848240153381885762b08f;p=dbsrgits%2FDBIx-Class-Historic.git diff --git a/lib/DBIx/Class/PK/Auto.pm b/lib/DBIx/Class/PK/Auto.pm index 64c8c83..523ec27 100644 --- a/lib/DBIx/Class/PK/Auto.pm +++ b/lib/DBIx/Class/PK/Auto.pm @@ -5,35 +5,25 @@ use base qw/DBIx::Class/; use strict; use warnings; -=head1 NAME +1; + +=head1 NAME DBIx::Class::PK::Auto - Automatic primary key class =head1 SYNOPSIS - # In your table classes (replace PK::Auto::SQLite with your database) - __PACKAGE__->load_components(qw/PK::Auto::SQLite Core/); - __PACKAGE__->set_primary_key('id'); +use base 'DBIx::Class::Core'; +__PACKAGE__->set_primary_key('id'); =head1 DESCRIPTION This class overrides the insert method to get automatically incremented primary keys. -You don't want to be using this directly - instead load the appropriate one for -your database, e.g. C, in your table classes: - - __PACKAGE__->load_components(qw/PK::Auto::SQLite Core/); - -Note that C is specified as the leftmost argument. - -Alternatively, you can load the components separately: +PK::Auto is now part of Core. - __PACKAGE__->load_components(qw/Core/); - __PACKAGE__->load_components(qw/PK::Auto::SQLite/); - -This can be used, for example, if you have different databases and need to -determine the appropriate C class at runtime. +See L for details of component interactions. =head1 LOGIC @@ -44,44 +34,12 @@ fetching the assigned value afterwards. =head2 insert -Overrides C so that it will get the value of autoincremented primary -keys. - -=cut - -sub insert { - my ($self, @rest) = @_; - my $ret = $self->next::method(@rest); - - my ($pri, $too_many) = grep { !defined $self->get_column($_) } $self->primary_columns; - return $ret unless defined $pri; # if all primaries are already populated, skip auto-inc - $self->throw_exception( "More than one possible key found for auto-inc on ".ref $self ) - if defined $too_many; - - my $storage = $self->result_source->storage; - $self->throw_exception( "Missing primary key but Storage doesn't support last_insert_id" ) unless $storage->can('last_insert_id'); - my $id = $storage->last_insert_id($self->result_source,$pri); - $self->throw_exception( "Can't get last insert id" ) unless $id; - $self->store_column($pri => $id); - - return $ret; -} +The code that was handled here is now in Row for efficiency. =head2 sequence -Manually define the correct sequence for your table, to avoid the overhead -associated with looking up the sequence automatically. - -=cut - -sub sequence { - my ($self,$seq) = @_; - foreach my $pri ($self->primary_columns) { - $self->column_info($pri)->{sequence} = $seq; - } -} - -1; +The code that was handled here is now in ResultSource, and is being proxied to +Row as well. =head1 AUTHORS