NAME
    DBIx::DBO2::ReadMe - Getting Started with DBIx::DBO2

SYNOPSIS
      package MyRecord;
      use DBIx::DBO2::Record '-isasubclass';
      my $sql_engine = DBIx::SQLEngine->new( $dsn, $user, $pass );
  
      MyRecord->table(
        DBIx::DBO2::Table->new(name=>'myrecords', datasource=>$sql_engine)
      );
  
      package main;
      my $results = MyRecord->fetch_all;
      foreach my $record ( $results->records ) {
        if ( $record->{age} > 20 ) {
          $record->{status} = 'adult';
          $record->save_row;
        }
      }

DESCRIPTION
    DBIx::DBO2 is an object-relational mapping framework (or perhaps a
    relational-object mapping framework, if I understand the distinction
    correctly) that facilitates the development of Perl classes whose
    objects are stored in a SQL database table.

INSTALLING
    You should be able to install this module using the CPAN shell
    interface:

      perl -MCPAN -e 'install DBIx::DBO2'

    If this module has not yet been posted to your local CPAN mirror, you
    may also retrieve the current distribution from the below address and
    follow the normal "gunzip", "tar xf", "cd", "perl Makefile.PL && make
    test && sudo make install" procedure or your local equivalent:

      http://www.evoscript.org/DBIx-DBO2/

  Getting Started

    You may want to take a look at the test.pl and test-lib/ classes
    included with this distribution for a short example of how to use this
    framework to create your own classes.

  Prerequisites

    Requires DBIx::SQLEngine and Class::MakeMethods, both available on CPAN.

  Tested Platforms

    This release has been tested succesfully on the following platforms:

      5.6.1 on darwin
      5.005_03 on i386-freebsd

VERSION
    This is version 0.003 of DBIx::DBO2.

  Distribution Summary

    This module's summary in the CPAN DSLIP is intended to read:

      Name            DSLIP  Description
      --------------  -----  ---------------------------------------------
      DBIx::
      :: DBO2         bdpOp  Objects mapping to SQL relational structures

  Beta Release

    Although it based on earlier code that was extensively tested over
    several years of production use, this code has recently been majorly
    refactored, and has not yet been sufficiently tested in its new form.

  Discussion and Support

    There is not currently any offical discussion and support forum for this
    pacakage.

    Further information and support for this module is available at
    http://www.evoscript.org.

    If you have questions or feedback about this module, please feel free to
    contact the author at the below address.

    I would be particularly interested in any suggestions towards improving
    the documentation, correcting any Perl-version or platform dependencies,
    as well as general feedback and suggestions.

SEE ALSO
    See the DBIx::SQLEngine manpage for information about the underlying
    database interface.

    See the DBIx::DBO2::Record manpage, the DBIx::DBO2::Fields manpage, the
    DBIx::DBO2::Table manpage, and the DBIx::DBO2::TableSet manpage for key
    interfaces.

  Similar Modules

    Numerous modules on CPAN provide some type of system to map objects to
    and from SQL databases, including the Class::DBI manpage, the Alzabo
    manpage, and the Tangram manpage.

    See the Poop Group summary at http://poop.sourceforge.net/ for a review
    of several other CPAN modules which provide a similar RDBMS-to-OO
    mapping layer.

    For comparison purposes, here are some of the questions asked by the
    Poop Group summary and their answers for this module:

    Supported Databases
        Currently supports DBD::AnyData, DBD::CSV, DBD::MySQL, and DBD::Pg.

        Providing support for other drivers involves creating a DBD-specific
        subclass of DBIx::SQLEngine (which will be loaded via DBIx::AnyDBD
        when appropriate), and should only require a limited amount of
        coding.

    SQL Abstraction
        This module supports moderately complex selects, inserts, updates,
        and deletes, based on the DBIx::SQLEngine abstraction layer. It is
        possible to apply order by and group by clauses to operations, as
        well as limits.

        Inserts with sequences are supported, with DBIX::SQLEngine providing
        a workaround using its own sequence table logic for DBDs which don't
        have native sequence/auto_increment equivalents.

        Joins are not supported, although it is possible to pass in snippets
        of SQL to accomplish this, or to provide your own logic in a
        subclass.

    Invalid SQL
        The automated SQL generation should produce valid SQL, but if you
        pass in incorrect information, such as explicitly requesting a
        column name which does not exist in the database, or if you pass in
        a SQL snippet as part of a query, there is no way to validate this
        prior to actually executing the query and receiving an error from
        the DBMS.

    Deferred/Preloaded data retrieval
        There is not yet any way to defer the loading of given columns for a
        select. However, it always possible to easily specify only those
        columns which are needed at a given point in your code. (Deferred
        loading of additional columns is expected in an upcomming release.)

    Table Relationships
        DBIx::DBO2 supports both many-to-one (foreign key) and one-to-many
        (reverse foreign key) relationships. Support for one-to-many
        relationships includes your choice of cascading delete, nullify
        after delete, and restrict delete rules. You can establish
        relationships between classes regardless of whether their data is
        actually stored in the same underlying SQL database.

    Multiple rows and cursors
        DBIx::DBO2 currently returns multiple rows all at once. A RecordSet
        object similar to a cursor is used by it does not yet handle
        incremental retrieval. (Support for cursors and automatic iteration
        with closures is expected in an upcomming release.)

    Caching
        There is no built in caching support. (Support for LRU caching and
        ensuring that there is only a single instance of a given object in
        memory at any time are both expected in an upcomming release.)

    Transactions
        DBIx::DBO2 does not support transactions. (Basic transactions for
        DBDs which support them are expected in an upcomming release.)

    Auto-generated methods
        The included DBIx::DBO2::Fields package can generate a wide variety
        of methods, including customized accessors for each type of field or
        relationship. (These currently require explicit declarations, but
        support for automatic detection of database columns and subsequent
        method generation is expected in an upcomming release.)

    Other
        A callback mechanism allows you to specify method names or arbitrary
        subroutines to be called immediately before or after each record is
        retrieved, inserted, updated, or deleted. You can add these
        callbacks to all record classes, to a particular class, or even to a
        particular object instance.

    Documentation
        The documentation for this module is still fairly rough, although
        efforts are continuing to improve this.

    License
        GPL/Artistic disjunction. The same as Perl itself.

    Support
        Support for this module is available from the author
        (simonm@cavalletto.org). (The author is also available for support
        contracts or consulting engagements.)

    Status
        Recently released to CPAN after several years of in-house use.
        Actively developed and supported by the author.

CREDITS AND COPYRIGHT
  Developed By

      M. Simon Cavalletto, simonm@cavalletto.org
      Evolution Softworks, www.evoscript.org

  Contributors

      Piglet / EJ Evans, piglet@piglet.org
      Eric Schneider, roark@evolution.com
      Chaos / Matthew Sheahan

  Copyright

    Copyright 2002 Matthew Simon Cavalletto.

    Portions copyright 1997, 1998, 1999, 2000, 2001 Evolution Online
    Systems, Inc.

  License

    You may use, modify, and distribute this software under the same terms
    as Perl.