NAME

DustyDB - yet another Moose-based object database

VERSION

version 0.01

SYNOPSIS

# Declare a model
package Book;
use Moose;
with 'DustyDB::Record';

has title  => ( is => 'rw', isa => 'Str',   traits => [ 'DustyDB::Key' ] );
has author => ( is => 'rw', isa => 'Author' );

# Declare another model
package Author;
use Moose;
with 'DustyDB::Record';

has name => ( is => 'rw', isa => 'Str',     traits => [ 'DustyDB::Key' ] );

# Get down to business
package main;
use DustyDB;

# Create/connect to the database
my $db = DustyDB->new( path => 'foo.db' );

# Get the model classes used to work with records
my $author = $db->model('Author');
my $book   = $db->model('Book');

{
    # Create a couple records
    my $the_damian = $author->construct( name => 'Damian Conway' );
    my $pbp        = $book->construct( 
        title  => 'Perl Best Practices', 
        author => $the_damian,
    );

    # Save them to the database
    $the_damian->save;
    $pbp->save;

    # See also create() to do construct()->save()
}

{
    # Load some records
    my $the_damian = Author->load( 'Damian Conway' );
    my $pbp        = Book->load( 'Perl Best Practicies' );

    # Retrieve some information
    print "TheDamian is ", $the_damian->name, "\n";
    print "His book is ", $pbp->title, "\n";

    # Delete them
    $the_damian->delete;
    $pbp->delete;
}

{
    # Collections of records
    my @all_authors = $author->all;
    my @some_books  = $book->all_where( title => qr/^[A-M]/i );

    # Iterate through records
    my $iter = $author->all;
    while (my $an_author = $author->next) {
        print "Author: ", $an_author->name, "\n";
    }
}

DESCRIPTION

Sometimes, I need to store an eeny-weeny bit of data, but I want it nicely structured with Moose, but I don't want to mess with a bunch of setup and bootstrapping and blah blah blah. I just want to write my script. This provides a mechanism to do that with very little overhead. There are very few frills either, so if you want something nicer, you'll have to build on or look into something else.

All the data is stored using DBM::Deep, so if you want to dig deeper into what's going on here, you can open the database using that library without going through DustyDB.

ATTRIBUTES

dbm

If you want to initialize the DBM::Deep database used yourself, please supply a "dbm" argument to the new constructor. You can also use this attribute to fetch the underlying DBM::Deep object being used. All data used by DustyDB is stored in this as a hash. The only key of that hash that is used is "models". If you want to store additional information in the database, please avoid that key.

Other keys might be used in the future, I suppose, but I can't know what that would be now so I'm not going to worry about it at the moment.

path

This is the path to the DBM::Deep database file. This must be supplied to the constructor, even if you supply your own "dbm" parameter.

METHODS

model

my $model = $db->model( $model_class_name );

Given a model class name, this returns a DustyDB::Model, which can be used to create model object and immediately save them to the database or load models stored in the database.

INTERNAL METHODS

table

Do not use this method unless you really need to. The regular interface is provided through "model". This provides access to the table of records in the database.

init_table

Do not use this method unless you really need to. This is used to perform some bootstrapping of the table in the database.

MODULE NAME

Why DustyDB? Well, I wanted a "dead simple database." DSD. D-S-D. Dusty. DustyDB. Lame or not, it was it is.