NAME

MongoDB::DBRef - Native DBRef support

VERSION

version 0.700.0

SYNOPSIS

my $dbref = MongoDB::DBRef->new( db => 'my_db', ref => 'my_collection', id => 123 );
$coll->insert( { foo => 'bar', other_doc => $dbref } );

my $other_doc = $coll->find_one( { foo => 'bar' } )->{other_doc}->fetch;

DESCRIPTION

This module provides support for database references (DBRefs) in the Perl MongoDB driver. A DBRef is a special embedded document which points to another document in the database. DBRefs are not the same as foreign keys and do not provide any referential integrity or constraint checking. For example, a DBRef may point to a document that no longer exists (or never existed.)

NAME

MongoDB::DBRef - A MongoDB database reference

ATTRIBUTES

db

Required. The database in which the referenced document lives. Either a MongoDB::Database object or a string containing the database name. The object will be coerced to string form.

ref

Required. The collection in which the referenced document lives. Either a MongoDB::Collection object or a string containing the collection name. The object will be coerced to string form.

id

Required. The _id value of the referenced document. If the _id is an ObjectID, then you must use a MongoDB::OID object.

client

Optional. A MongoDB::MongoClient object to be used to fetch the referenced document from the database. You must supply this attribute if you want to use the fetch method.

When you retrieve a document from MongoDB, any DBRefs will automatically be inflated into MongoDB::DBRef objects with the client attribute automatically populated.

It is not necessary to specify a client if you are just making DBRefs to insert in the database as part of a larger document.

verify_db

Optional. Check that the referenced database exists before trying to fetch a document from it. The default is 1. Set to 0 to disable checking.

verify_coll

Optional. Check that the referenced collection exists before trying to fetch a document from it. The default is 1. Set to 0 to disable checking.

METHODS

fetch

Retrieve the referenced document from the database. If the document does not exist, you'll get back undef. You must populate the client attribute of the DBRef object in order to use this method. If there's no client, fetch will throw a fatal error.

If verify_db or <verify_coll> are on, fetch will throw a fatal error if the database or collection concerned does not exist.

AUTHORS

  • Florian Ragwitz <rafl@debian.org>

  • Kristina Chodorow <kristina@mongodb.org>

  • Mike Friedman <mike.friedman@10gen.com>

COPYRIGHT AND LICENSE

This software is Copyright (c) 2013 by 10gen, Inc..

This is free software, licensed under:

The Apache License, Version 2.0, January 2004