NAME

DBIx::Mint::Table - Role that maps a class to a table

SYNOPSIS

# In your class:

package Bloodbowl::Coach;
use Moo;
with 'DBIx::Mint::Table';

has 'id'     => ( is => 'rwp', required => 1 );
has 'name'   => ( is => 'ro',  required => 1 );
....

# And in your schema:
$schema->add_class(
   class   => 'Bloodbowl::Coach',
   table   => 'coaches',
   pk      => 'id',
   auto_pk => 1
);

# Finally, in your application:
my $coach = Bloodbowl::Coach->find(3);
say $coach->name;

$coach->name('Will E. Coyote');
$coach->update;

my @ids = Bloodbowl::Coach->insert(
   { name => 'Coach 1' },
   { name => 'Coach 2' },
   { name => 'Coach 3' }
);

$coach->delete;

my $coach = Bloodbowl::Coach->find_or_create(3);
say $coach->id;

# The following two lines are equivalent:
my $rs = Bloodbowl::Coach->result_set;
my $rs = DBIx::Mint::ResultSet->new( table => 'coaches' );

DESCRIPTION

This role allows your class to interact with a database table. It allows for record modification (insert, update and delete records) as well as data fetching via DBIx::Mint::ResultSet objects.

Database modification methods can be called as instance or class methods. In the first case, they act only on the calling object. When called as class methods they allow for the modification of several records.

Triggers can be added using the methods before, after, and around from Class::Method::Modifiers.

METHODS

insert

When called as a class method, it takes a list of hash references and inserts them into the table which corresponds to the calling class. The hash references must have the same keys to benefit from a prepared statement holder. The list of fields is taken from the first record. If only one record is used, it can be simply a list of key-value pairs.

When called as an instance method, it inserts the data contained within the object into the database.

create

This methods is a convenience that calls new and insert to create a new object. The following two lines are equivalent:

my $coach = Bloodbowl::Coach->create( name => 'Will E. Coyote');
my $coach = Bloodbowl::Coach->new( name => 'Will E. Coyote')->insert;

update

When called as a class method it will act over the whole table. The first argument defines the change to update and the second, the conditions that the records must comply with to be updated:

Bloodbowl::Coach->update( { email => 'unknown'}, { email => undef });

When called as an instance method it updates only the record that corresponds to the calling object:

$coach->name('Mr. Will E. Coyote');
$coach->update;

delete

This method deletes information from the corresponding table. Like insert and delete, if it is called as a class method it acts on the whole table; when called as an instance method it deletes the calling object from the database:

Bloodbowl::Coach->delete({ email => undef });
$coach->delete;

find

Fetches a single record from the database and blesses it into the calling class. It can be called as a class record only. It can as take as input either the values of the primary keys for the corresponding table or a hash reference with criteria to fetch a single record:

my $coach_3 = Bloodbowl::Coach->find(3);
my $coach_3 = Bloodbowl::Coach->find({ name => 'coach 3'});

find_or_create

This method will call 'create' if it cannot find a given record in the database.

SEE ALSO

This module is part of DBIx::Mint.

AUTHOR

Julio Fraire, <julio.fraire@gmail.com>

LICENCE AND COPYRIGHT

Copyright (c) 2013, Julio Fraire. All rights reserved.

LICENSE

This module is free software; you can redistribute it and/or modify it under the same terms as Perl itself. See perlartistic.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.