Added startup checks to warn loudly if we appear to be running on RedHat systems...
[dbsrgits/DBIx-Class.git] / lib / DBIx / Class / Manual / Intro.pod
1 =head1 NAME
2
3 DBIx::Class::Manual::Intro - Introduction to DBIx::Class
4
5 =head1 INTRODUCTION
6
7 You're bored with SQL, and want a native Perl interface for your database?  Or
8 you've been doing this for a while with L<Class::DBI>, and think there's a
9 better way?  You've come to the right place.
10
11 =head1 THE DBIx::Class WAY
12
13 Here are a few simple tips that will help you get your bearings with
14 DBIx::Class.  
15
16 =head2 Tables become ResultSources
17
18 DBIx::Class needs to know what your Table structure looks like.  You do that by
19 defining L<DBIx::Class::ResultSource>s.  Each table gets a ResultSource, which
20 defines the Columns it has, along with any Relationships it has to other tables.
21 (And oh, so much more besides)  The important thing to understand:
22
23   A ResultSource == Table
24
25 (most of the time, but just bear with my simplification)
26
27 =head2 It's all about the ResultSet
28
29 So, we've got some ResultSources defined.  Now, we want to actually use those
30 definitions to help us translate the queries we need into handy perl objects!  
31
32 Let's say we defined a ResultSource for an "album" table with three columns:
33 "albumid", "artist", and "title".  Any time we want to query this table, we'll
34 be creating a L<DBIx::Class::ResultSet> from its ResultSource.  For example, the
35 results of:
36
37   SELECT albumid, artist, title FROM album;
38
39 Would be retrieved by creating a ResultSet object from the album table's
40 ResultSource, likely by using the "search" method.  
41
42 DBIx::Class doesn't limit you to creating only simple ResultSets -- if you
43 wanted to do something like:
44
45   SELECT title FROM album GROUP BY title;
46
47 You could easily achieve it. 
48
49 The important thing to understand: 
50
51   Any time you would reach for a SQL query in DBI, you are 
52   creating a DBIx::Class::ResultSet.
53
54 =head2 Search is like "prepare"
55
56 DBIx::Class tends to wait until it absolutely must fetch information from the
57 database.  If you are returning a ResultSet, the query won't execute until you
58 use a method that wants to access the data. (Such as "next", or "first")
59
60 The important thing to understand:
61
62   Setting up a ResultSet does not execute the query; retrieving
63   the data does.
64
65 =head1 SETTING UP DBIx::Class
66
67 Let's look at how you can set and use your first native L<DBIx::Class> tree.
68
69 First we'll see how you can set up your classes yourself.  If you want them to
70 be auto-discovered, just skip to the next section, which shows you how to use
71 L<DBIx::Class::Schema::Loader>.
72
73 =head2 Setting it up manually
74
75 First, you should create your base schema class, which inherits from
76 L<DBIx::Class::Schema>:
77
78   package My::Schema;
79   use base qw/DBIx::Class::Schema/;
80
81 In this class you load your result_source ("table", "model") classes, which we
82 will define later, using the load_classes() method. You can specify which
83 classes to load manually: 
84
85   # load My::Schema::Album and My::Schema::Artist
86   __PACKAGE__->load_classes(qw/ Album Artist /);
87
88 Or load classes by namespace:
89
90   # load My::Schema::Album, My::Schema::Artist and My::OtherSchema::LinerNotes
91   __PACKAGE__->load_classes(
92     {
93       'My::Schema' => [qw/ Album Artist /],
94       'My::OtherSchema' => [qw/ LinerNotes /]
95     }
96   );
97
98 Or let your schema class load all classes in its namespace automatically:
99
100    # load My::Schema::*
101   __PACKAGE__->load_classes();
102
103 Next, create each of the classes you want to load as specified above:
104
105   package My::Schema::Album;
106   use base qw/DBIx::Class/;
107
108 Load any components required by each class with the load_components() method.
109 This should consist of "Core" plus any additional components you want to use.
110 For example, if you want serial/auto-incrementing primary keys:
111
112   __PACKAGE__->load_components(qw/ PK::Auto Core /);
113
114 C<PK::Auto> is supported for many databases; see L<DBIx::Class::Storage::DBI>
115 for more information.
116
117 Set the table for your class:
118
119   __PACKAGE__->table('album');
120
121 Add columns to your class:
122
123   __PACKAGE__->add_columns(qw/ albumid artist title /);
124
125 Each column can also be set up with its own accessor, data_type and other pieces
126 of information that it may be useful to have -- just pass C<add_columns> a hash:
127
128   __PACKAGE__->add_columns(albumid =>
129                             { accessor  => 'album',
130                               data_type => 'integer',
131                               size      => 16,
132                               is_nullable => 0,
133                               is_auto_increment => 1,
134                               default_value => '',
135                             },
136                           artist =>
137                             { data_type => 'integer',
138                               size      => 16,
139                               is_nullable => 0,
140                               is_auto_increment => 0,
141                               default_value => '',
142                             },
143                           title  => 
144                             { data_type => 'varchar',
145                               size      => 256,
146                               is_nullable => 0,
147                               is_auto_increment => 0,
148                               default_value => '',
149                             }
150                          );
151
152 DBIx::Class doesn't directly use most of this data yet, but various related
153 modules such as L<DBIx::Class::WebForm> make use of it. Also it allows you to
154 create your database tables from your Schema, instead of the other way around.
155 See L<SQL::Translator> for details.
156
157 See L<DBIx::Class::ResultSource> for more details of the possible column
158 attributes.
159
160 Accessors are created for each column automatically, so My::Schema::Album will
161 have albumid() (or album(), when using the accessor), artist() and title()
162 methods.
163
164 Define a primary key for your class:
165
166   __PACKAGE__->set_primary_key('albumid');
167
168 If you have a multi-column primary key, just pass a list instead:
169
170   __PACKAGE__->set_primary_key( qw/ albumid artistid / );
171
172 Define this class' relationships with other classes using either C<belongs_to>
173 to describe a column which contains an ID of another Table, or C<has_many> to
174 make a predefined accessor for fetching objects that contain this Table's
175 foreign key:
176
177   __PACKAGE__->has_many('albums', 'My::Schema::Artist', 'album_id');
178
179 See L<DBIx::Class::Relationship> for more information about the various types of
180 available relationships and how you can design your own.
181
182 =head2 Using L<DBIx::Class::Schema::Loader>
183
184 This is an external module, and not part of the L<DBIx::Class> distribution.
185 Like L<Class::DBI::Loader>, it inspects your database, and automatically creates
186 classes for all the tables in your database.  Here's a simple setup:
187
188   package My::Schema;
189   use base qw/DBIx::Class::Schema::Loader/;
190
191   __PACKAGE__->loader_options( relationships => 1 );
192
193   1;
194
195 The actual autoloading process will occur when you create a connected instance
196 of your schema below.
197
198 See the L<DBIx::Class::Schema::Loader> documentation for more information on its
199 many options.
200
201 =head2 Connecting
202
203 To connect to your Schema, you need to provide the connection details.  The
204 arguments are the same as for L<DBI/connect>:
205
206   my $schema = My::Schema->connect('dbi:SQLite:/home/me/myapp/my.db');
207
208 You can create as many different schema instances as you need. So if you have a
209 second database you want to access:
210
211   my $other_schema = My::Schema->connect( $dsn, $user, $password, $attrs );
212
213 Note that L<DBIx::Class::Schema> does not cache connections for you. If you use
214 multiple connections, you need to do this manually.
215
216 To execute some sql statements on every connect you can add them as an option in
217 a special fifth argument to connect:
218
219   my $another_schema = My::Schema->connect(
220       $dsn,
221       $user,
222       $password,
223       $attrs,
224       { on_connect_do => \@on_connect_sql_statments }
225   );
226
227 See L<DBIx::Class::Schema::Storage::DBI/connect_info> for more information about
228 this and other special C<connect>-time options.
229
230 =head2 Basic usage
231
232 Once you've defined the basic classes, either manually or using
233 L<DBIx::Class::Schema::Loader>, you can start interacting with your database.
234
235 To access your database using your $schema object, you can fetch a
236 L<DBIx::Class::Manual::Glossary/"ResultSet"> representing each of your tables by
237 calling the C<resultset> method.
238
239 The simplest way to get a record is by primary key:
240
241   my $album = $schema->resultset('Album')->find(14);
242
243 This will run a C<SELECT> with C<albumid = 14> in the C<WHERE> clause, and
244 return an instance of C<My::Schema::Album> that represents this row.  Once you
245 have that row, you can access and update columns:
246
247   $album->title('Physical Graffiti');
248   my $title = $album->title; # $title holds 'Physical Graffiti'
249
250 If you prefer, you can use the C<set_column> and C<get_column> accessors
251 instead:
252
253   $album->set_column('title', 'Presence');
254   $title = $album->get_column('title');
255
256 Just like with L<Class::DBI>, you call C<update> to commit your changes to the
257 database:
258
259   $album->update;
260
261 If needed, you can throw away your local changes:
262
263   $album->discard_changes if $album->is_changed;
264
265 As you can see, C<is_changed> allows you to check if there are local changes to
266 your object.
267
268 =head2 Adding and removing rows
269
270 To create a new record in the database, you can use the C<create> method.  It
271 returns an instance of C<My::Schema::Album> that can be used to access the data
272 in the new record:
273
274   my $new_album = $schema->resultset('Album')->create({ 
275     title  => 'Wish You Were Here',
276     artist => 'Pink Floyd'
277   });
278
279 Now you can add data to the new record:
280
281   $new_album->label('Capitol');
282   $new_album->year('1975');
283   $new_album->update;
284
285 Likewise, you can remove it from the database:
286
287   $new_album->delete;
288
289 You can also remove records without retrieving them first, by calling delete
290 directly on a ResultSet object.
291
292   # Delete all of Falco's albums
293   $schema->resultset('Album')->search({ artist => 'Falco' })->delete;
294
295 =head2 Finding your objects
296
297 L<DBIx::Class> provides a few different ways to retrieve data from your
298 database.  Here's one example:
299
300   # Find all of Santana's albums
301   my $rs = $schema->resultset('Album')->search({ artist => 'Santana' });
302
303 In scalar context, as above, C<search> returns a L<DBIx::Class::ResultSet>
304 object.  It can be used to peek at the first album returned by the database:
305
306   my $album = $rs->first;
307   print $album->title;
308
309 You can loop over the albums and update each one:
310
311   while (my $album = $rs->next) {
312     print $album->artist . ' - ' . $album->title;
313     $album->year(2001);
314     $album->update;
315   }
316
317 Or, you can update them all at once:
318
319   $rs->update({ year => 2001 });
320
321 In list context, the C<search> method returns all of the matching rows:
322
323   # Fetch immediately all of Carlos Santana's albums
324   my @albums = $schema->resultset('Album')->search(
325     { artist => 'Carlos Santana' }
326   );
327   foreach my $album (@albums) {
328     print $album->artist . ' - ' . $album->title;
329   }
330
331 We also provide a handy shortcut for doing a C<LIKE> search:
332
333   # Find albums whose artist starts with 'Jimi'
334   my $rs = $schema->resultset('Album')->search_like({ artist => 'Jimi%' });
335
336 Or you can provide your own C<WHERE> clause:
337
338   # Find Peter Frampton albums from the year 1986
339   my $where = 'artist = ? AND year = ?';
340   my @bind  = ( 'Peter Frampton', 1986 );
341   my $rs    = $schema->resultset('Album')->search_literal( $where, @bind );
342
343 The preferred way to generate complex queries is to provide a L<SQL::Abstract>
344 construct to C<search>:
345
346   my $rs = $schema->resultset('Album')->search({
347     artist  => { '!=', 'Janis Joplin' },
348     year    => { '<' => 1980 },
349     albumid => { '-in' => [ 1, 14, 15, 65, 43 ] }
350   });
351
352 This results in something like the following C<WHERE> clause:
353
354   WHERE artist != 'Janis Joplin'
355     AND year < 1980
356     AND albumid IN (1, 14, 15, 65, 43)
357
358 For more examples of complex queries, see L<DBIx::Class::Manual::Cookbook>.
359
360 The search can also be modified by passing another hash with
361 attributes:
362
363   my @albums = My::Schema->resultset('Album')->search(
364     { artist => 'Bob Marley' },
365     { rows => 2, order_by => 'year DESC' }
366   );
367
368 C<@albums> then holds the two most recent Bob Marley albums.
369
370 For more information on what you can do with a L<DBIx::Class::ResultSet>, see
371 L<DBIx::Class::ResultSet/METHODS>.
372
373 For a complete overview of the available attributes, see
374 L<DBIx::Class::ResultSet/ATTRIBUTES>.
375
376 =head1 NOTES
377
378 =head2 Problems on RHEL5/CentOS5
379
380 There is a problem with slow performance of certain DBIx::Class operations in
381 perl-5.8.8-10 and later on RedHat and related systems, due to a bad backport of
382 a "use overload" related bug.  The problem is in the Perl binary itself, not in
383 DBIx::Class.  If your system has this problem, you will see a warning on
384 startup, with some options as to what to do about it.
385
386 =head1 SEE ALSO
387
388 =over 4
389
390 =item * L<DBIx::Class::Manual::Cookbook>
391
392 =back
393
394 =cut