=head1 NAME DBIx::Class::Manual::Intro - Introduction to DBIx::Class =head1 INTRODUCTION So, you are bored with SQL, and want a native Perl interface for your database? Or you've been doing this for a while with L, and think there's a better way? You've come to the right place. =head1 THE DBIx::Class WAY Here are a few simple tips that will help you get your bearings with DBIx::Class. =head2 Tables become ResultSources DBIx::Class needs to know what your Table structure looks like. You do that by defining Ls. Each table get's a ResultSource, which defines the Columns it has, along with any Relationships it has to other tables. (And oh, so much more besides) The important thing to understand: A ResultSource == Table (most of the time, but just bear with my simplification) =head2 It's all about the ResultSet So, we've got some ResultSources defined. Now, we want to actually use those definitions to help us translate the queries we need into handy perl objects! Let's say we defined a ResultSource for an "album" table with three columns: "albumid", "artist", and "title". Any time we want to query this table, we'll be creating a L from it's ResultSource. For example, the results of: SELECT albumid, artist, title FROM album; Would be retrieved by creating a ResultSet object from the album table's ResultSource, likely by using the "search" method. DBIx::Class doesn't limit you to creating only simple ResultSets -- if you wanted to do something like: SELECT title FROM album GROUP BY title; You could easily achieve it. The important thing to understand: Any time you would reach for a SQL query in DBI, you are creating a DBIx::Class::ResultSet. =head2 Search is like "prepare" DBIx::Class tends to wait until it absolutely must fetch information from the database. If you are returning a ResultSet, the query won't execute until you use a method that wants to access the data. (Such as "next", or "first") The important thing to understand: Setting up a ResultSet does not execute the query; retrieving the data does. =head1 SETTING UP DBIx::Class Let's look at how you can set and use your first native L tree. First we'll see how you can set up your classes yourself. If you want them to be auto-discovered, just skip to the next section, which shows you how to use L. =head2 Setting it up manually First, you should create your base schema class, which inherits from L: package My::Schema; use base qw/DBIx::Class::Schema/; In this class you load your result_source ("table", "model") classes, which we will define later, using the load_classes() method. You can specify which classes to load manually: # load My::Schema::Album and My::Schema::Artist __PACKAGE__->load_classes(qw/ Album Artist /); Or load classes by namespace: # load My::Schema::Album, My::Schema::Artist and My::OtherSchema::LinerNotes __PACKAGE__->load_classes( { 'My::Schema' => [qw/ Album Artist /], 'My::OtherSchema' => [qw/ LinerNotes /] } ); Or let your schema class load all classes in its namespace automatically: # load My::Schema::* __PACKAGE__->load_classes(); Next, create each of the classes you want to load as specified above: package My::Schema::Album; use base qw/DBIx::Class/; Load any components required by each class with the load_components() method. This should consist of "Core" plus any additional components you want to use. For example, if you want serial/auto-incrementing primary keys: __PACKAGE__->load_components(qw/ PK::Auto Core /); C is supported for many databases; see L for more information. Set the table for your class: __PACKAGE__->table('album'); Add columns to your class: __PACKAGE__->add_columns(qw/ albumid artist title /); Each column can also be set up with its own accessor, data_type and other pieces of information that it may be useful to have, just pass C a hash such as: __PACKAGE__->add_columns(albumid => { accessor => 'album', data_type => 'integer', size => 16, is_nullable => 0, is_auto_increment => 1, default_value => '', }, artist => { data_type => 'integer', size => 16, is_nullable => 0, is_auto_increment => 0, default_value => '', }, title => { data_type => 'varchar', size => 256, is_nullable => 0, is_auto_increment => 0, default_value => '', } ); Most of this data isn't yet used directly by DBIx::Class, but various related modules such as L make use of it. Also it allows you to create your database tables from your Schema, instead of the other way around. See L for details. See L for more details of the possible column attributes. Accessors are created for each column automatically, so My::Schema::Album will have albumid() (or album(), when using the accessor), artist() and title() methods. Define a primary key for your class: __PACKAGE__->set_primary_key('albumid'); If you have a multi-column primary key, just pass a list instead: __PACKAGE__->set_primary_key( qw/ albumid artistid / ); Define relationships that the class has with any other classes by using either C to describe a column which contains an ID of another table, or C to make a predefined accessor for fetching objects that contain this tables foreign key in one of their columns: __PACKAGE__->has_many('albums', 'My::Schema::Artist', 'album_id'); More information about the various types of relationships available, and how you can design your own, can be found in L. =head2 Using L This is an external module, and not part of the L distribution. Like L, it inspects your database, and automatically creates classes for all the tables in your database. Here's a simple setup: package My::Schema; use base qw/DBIx::Class::Schema::Loader/; __PACKAGE__->loader_options( relationships => 1 ); 1; The actual autoloading process will occur when you create a connected instance of your schema below. L takes lots of other options. For more information, consult its documentation. =head2 Connecting To connect to your Schema, you also need to provide the connection details. The arguments are the same as you would use for L: my $schema = My::Schema->connect('dbi:SQLite:/home/me/myapp/my.db'); You can create as many different schema instances as you need. So if you have a second database you want to access: my $other_schema = My::Schema->connect( $dsn, $user, $password, $attrs ); Note that L does not cache connections for you. If you use multiple connections, you need to do this manually. To execute some sql statements on every connect you can add them as an option in a special fifth argument to connect, like so: my $another_schema = My::Schema->connect( $dsn, $user, $password, $attrs, { on_connect_do => \@on_connect_sql_statments } ); For more information about this and other special C-time options, see L. =head2 Basic usage Once you've defined the basic classes, either manually or using L, you can start interacting with your database. To access your database using your $schema object, you can fetch a L representing each of your tables by calling the ->resultset method. The simplest way to get a record is by primary key: my $album = $schema->resultset('Album')->find(14); This will run a C