=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. 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__->load_from_connection( connect_info = [ 'dbi:SQLite:/home/me/myapp/my.db' ] ); 1; This should be equivalent to the manual setup in the section above. L takes lots of other options. For more information, consult its documentation. =head2 Connecting L already contains the connection info for the database, so to get started all you need to do is create an instance of your class: my $schema = My::Schema->new(); To connect to your manually created Schema, you also need to provide the connection details: 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 connnections for you. If you use multiple connections, you need to do this manually. To execute some sql statements on every connect you can pass them to your schema after the connect: $schema->storage->on_connect_do(\@on_connect_sql_statments); =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