Changes for version 0.08008 - 2007-11-16

  • Fixed join merging bug (test from Zby)
  • When adding relationships, it will throw an exception if you get the foreign and self parts the wrong way round in the condition
  • ResultSetColumn::func() now returns all results if called in list context; this makes things like func('DISTINCT') work as expected
  • Many-to-many relationships now warn if the utility methods would clash
  • InflateColumn::DateTime now accepts an extra parameter of timezone to set timezone on the DT object (thanks Sergio Salvi)
  • Added sqlt_deploy_hook to result classes so that indexes can be added.
  • Added startup checks to warn loudly if we appear to be running on RedHat systems from perl-5.8.8-10 and up that have the bless/overload patch applied (badly) which causes 2x -> 100x performance penalty. (Jon Schutz)
  • ResultSource::reverse_relationship_info can distinguish between sources using the same table
  • Row::insert will now not fall over if passed duplicate related objects
  • Row::copy will not fall over if you have two relationships to the same source with a unique constraint on it


Index of the Manual
Developing DBIx::Class Components
Miscellaneous recipes
What documentation do we have?
Simple CD database example
Frequently Asked Questions (in theory)
Clarification of terms used.
Introduction to DBIx::Class
Manual on joining tables with DBIx::Class
Got a problem? Shoot it.
Execute operations upon DBIx::Class objects.


Extensible and flexible object <-> relational mapper.
See Class::Accessor::Grouped
Class::DBI Compatibility layer.
Core set of DBIx::Class modules
Abstract object representing a query cursor on a resultset.
(DEPRECATED) classdata schema component
Exception objects for DBIx::Class
Automatically create references from column data
Auto-create DateTime objects from date and datetime columns.
map files from the Database to the filesystem.
Modify the position of objects in an ordered list.
Primary Key class
Automatic primary key class
(DEPRECATED) Automatic primary key class for DB2
(DEPRECATED) Automatic primary key class for MSSQL
(DEPRECATED) Automatic primary key class for MySQL
(DEPRECATED) Automatic primary key class for Oracle
(DEPRECATED) Automatic primary key class for Pg
(DEPRECATED) Automatic primary key class for SQLite
Inter-table relationships
Inter-table relationships
Responsible for fetching and creating resultset.
helpful methods for messing with a single column of the resultset
helpful methods for managing resultset classes (EXPERIMENTAL)
Result source object
provides a classdata table object and method proxies
Basic row methods
composable schemas
DBIx::Class::Schema plugin for Schema upgrades
hooks for Storable freeze/thaw
Run environment checks on startup
Generic Storage Handler
DBI storage handler
Object representing a query cursor on a resultset.
Automatic primary key class for DB2
Storage::DBI subclass for MSSQL
Some databases can't handle count distincts with multiple cols. They should use base on this.
Sometime DBDs have poor to no support for bind variables
Base class for ODBC drivers
Support specific to DB2/400 over ODBC
Base class for Oracle driver
Automatic primary key class for Oracle
Oracle joins in WHERE syntax support (instead of ANSI).
Automatic primary key class for PostgreSQL
EXPERIMENTAL Replicated database support
Automatic primary key class for SQLite
Storage::DBI subclass for Sybase
Storage::DBI subclass for MSSQL via DBD::Sybase
Automatic primary key class for MySQL
Base class for running Class::DBI tests against DBIx::Class compat layer, shamelessly ripped from Class::DBI::Test::SQLite
Force UTF8 (Unicode) flag on columns


in lib/DBIx/Class/Storage/
in lib/DBIx/Class/Storage/DBI/Oracle/
in lib/DBIx/Class/CDBICompat/
in lib/DBIx/Class/Schema/
in lib/DBIx/Class/Schema/
in lib/DBIx/Class/