NAME
    Data::Model - model interface which had more data sources unified, a.k.a
    data/object mapper

SYNOPSIS
      package Your::Model;
      use base 'Data::Model';
      use Data::Model::Schema;
      use Data::Model::Driver::DBI;
  
      my $dbfile = '/foo/bar.db';
      my $driver = Data::Model::Driver::DBI->new(
          dsn => "dbi:SQLite:dbname=$dbfile",
      );
      base_driver( $driver );
  
      install_model user => schema {
          key 'id';
          columns qw/
              id
              name
          /;
      };
  
      # create database file
      unless (-f $dbfile) {
          my $dbh = DBI->connect($dsn, '', '', { RaiseError => 1, PrintError => 0 });
          for my $sql (__PACKAGE__->as_sqls) {
              $dbh->do( $sql );
          }
          $dbh->disconnect;
      }
  
      # in your script:
      use Your::Model;
  
      my $model = Your::Model->new;
  
      # insert
      my $row = $model->set(
          user => {
              id => 1,
          }
      );
  
      my $row = $model->lookup( user => 1 );
      $row->delete;

DESCRIPTION
    Data::Model is can use as ORM which can be defined briefly.

    There are few documents. It is due to be increased in the near future.

SCHEMA DEFINITION
    One package can define two or more tables using DSL.

    see Data::Model::Schema.

METHODS
  new([ \%options ]);
      my $model = Class->new;

  lookup($target => $key)
      my $row = $model->lookup( user => $id );
      print $row->name;

  lookup_multi($target => \@keylist)
      my @row = $model->lookup_multi( user => [ $id1, $id2 ] );
      print $row[0]->name;
      print $row[1]->name;

  get($target => $key [, \%options ])
      my $iterator = $model->get( user => { 
          id => {
              IN => [ $id1, $id2 ],
          }
      });
      while (my $row = $iterator->next) {
          print $row->name;
      }
      # or
      while (my $row = <$iterator>) {
          print $row->name;
      }
      # or
      while (<$iterator>) {
          print $_->name;
      }

  set($target => $key, => \%values [, \%options ])
      $model->set( user => {
        id   => 3,
        name => 'insert record',
      });

  delete($target => $key [, \%options ])
      $model->delete( user => 3 ); # id = 3 is deleted

ROW OBJECT METHODS
    row object is provided by Data::Model::Row.

  update
      my $row = $model->lookup( user => $id );
      $row->name('update record');
      $row->update;

  delete
      my $row = $model->lookup( user => $id );
      $row->delete;

TRANSACTION
    see Data::Model::Transaction.

DATA DRIVERS
  DBI
    see Data::Model::Driver::DBI.

  DBI::MasterSlave
    master-slave composition for mysql.

    see Data::Model::Driver::DBI::MasterSlave.

  Cache
    Cash of the result of a query.

    see Data::Model::Driver::Cache::HASH, see
    Data::Model::Driver::Cache::Memcached.

  Memcached
    memcached is used for data storage.

    see Data::Model::Driver::Memcached.

  Queue::Q4M
    queuing manager for Q4M.

    see Data::Model::Driver::Queue::Q4M.

  Memory
    on memory storage.

    see Data::Model::Driver::Memory.

SEE ALSO
    Data::Model::Row, Data::Model::Iterator

ACKNOWLEDGEMENTS
    Benjamin Trott more idea given by Data::ObjectDriver

AUTHOR
    Kazuhiro Osawa <yappo <at> shibuya <dĂśt> pl>

REPOSITORY
      git clone git://github.com/yappo/p5-Data-Model.git

    Data::Model's Git repository is hosted at
    <http://github.com/yappo/p5-Data-Model>. patches and collaborators are
    welcome.

LICENSE
    This library is free software; you can redistribute it and/or modify it
    under the same terms as Perl itself.