lib/DBIx/Class/DB.pm
lib/DBIx/Class/Exception.pm
lib/DBIx/Class/InflateColumn.pm
+lib/DBIx/Class/Manual.pod
+lib/DBIx/Class/Manual/Cookbook.pod
+lib/DBIx/Class/Manual/FAQ.pod
+lib/DBIx/Class/Manual/Intro.pod
+lib/DBIx/Class/Manual/Troubleshooting.pod
+lib/DBIx/Class/ObjectCache.pm
lib/DBIx/Class/PK.pm
lib/DBIx/Class/PK/Auto.pm
lib/DBIx/Class/PK/Auto/MSSQL.pm
---
name: DBIx-Class
-version: 0.03001
+version: 0.03002
author:
- Matt S. Trout <mst@shadowcatsystems.co.uk>
abstract: Extensible and flexible object <-> relational mapper.
file: lib/DBIx/Class/Storage/DBI.pm
DBIx::Class:
file: lib/DBIx/Class.pm
- version: 0.03001
+ version: 0.03002
DBIx::Class::AccessorGroup:
file: lib/DBIx/Class/AccessorGroup.pm
DBIx::Class::CDBICompat:
file: lib/DBIx/Class/Exception.pm
DBIx::Class::InflateColumn:
file: lib/DBIx/Class/InflateColumn.pm
+ DBIx::Class::ObjectCache:
+ file: lib/DBIx/Class/ObjectCache.pm
DBIx::Class::PK:
file: lib/DBIx/Class/PK.pm
DBIx::Class::PK::Auto:
file: lib/DBIx/Class/Table.pm
DBIx::Class::Test::SQLite:
file: lib/DBIx/Class/Test/SQLite.pm
+ DBIx::Class::UUIDColumns:
+ file: lib/DBIx/Class/UUIDColumns.pm
DBIx::ContextualFetch::st:
file: lib/DBIx/Class/CDBICompat/ImaDBI.pm
-generated_by: Module::Build version 0.2611
+generated_by: Module::Build version 0.2607
IRC: irc.perl.org#dbix-class
QUICKSTART
- If you're using Class::DBI, replacing
+ If you're using Class::DBI, and want an easy and fast way of migrating
+ to DBIx::Class look at DBIx::Class::CDBICompat.
- use base qw/Class::DBI/;
+ There are two ways of using DBIx::Class, the 'simple' and the 'schema'
+ one.
- with
+ The 'simple' way of using DBIx::Class needs less classes than the
+ 'schema' way but doesn't give you the ability to use different database
+ connections.
- use base qw/DBIx::Class/;
- __PACKAGE__->load_components(qw/CDBICompat Core DB/);
+ Some examples where different database connections are useful are:
- will probably get you started.
+ different users with different rights different databases with the same
+ schema.
- If you're using AUTO_INCREMENT for your primary columns, you'll also
- want yo load the approriate PK::Auto subclass - e.g.
+Simple
+ First you need to create a base class all other classes inherit from.
- __PACKAGE__->load_components(qw/CDBICompat PK::Auto::SQLite Core DB/);
+ Look at DBIx::Class::DB how to do this
- (with is what ::Test::SQLite does to present the
- Class::DBI::Test::SQLite interface)
+ Next you need to create a class for every table you want to use with
+ DBIx::Class.
- If you fancy playing around with DBIx::Class from scratch, then read the
- docs for DBIx::Class::Table, ::Row, ::Schema, ::DB and ::Relationship,
+ Look at DBIx::Class::Table how to do this.
- use base qw/DBIx::Class/;
- __PACKAGE__->load_components(qw/Core DB/);
+ Schema
+ With this approach the table classes inherit directly from
+ DBIx::Class::Core, although it might be a good idea to create a 'parent'
+ class for all table classes which inherits from DBIx::Class::Core and
+ adds additional methods needed by all table classes, e.g. reading a
+ config file, loading auto primary key support.
- and have a look at t/lib/DBICTest.pm for a brief example.
+ Look at DBIx::Class::Schema how to do this.
+
+ If you need more hand-holding, check out the introduction in the manual
+ below.
+
+SEE ALSO
+ DBIx::Class::Core - DBIC Core Classes
+ DBIx::Class::CDBICompat - Class::DBI Compat layer.
+ DBIx::Class::Manual - User's manual.
AUTHOR
Matt S. Trout <mst@shadowcatsystems.co.uk>
well as subclasses for each of your database classes in this namespace, using
this connection.
+It will also setup a ->table method on the target class, which lets you
+resolve database classes based on the schema component name, for example
+
+ MyApp::DB->table('Foo') # returns MyApp::DB::Foo,
+ # which ISA MyApp::Schema::Foo
+
+This is the recommended API for accessing Schema generated classes, and
+using it might give you instant advantages with future versions of DBIC.
+
=cut
sub compose_connection {