NAME
Database::Async::ORM - provides object-relational features for Database::Async
SYNOPSIS
use 5.020;
use IO::Async::Loop;
use Database::Async::ORM;
my $loop = IO::Async::Loop->new;
$loop->add(
my $orm = Database::Async::ORM->new
);
# Load schemata directly from the database
$orm->load_from($db)
->then(sub {
say 'We have the following tables:';
$orm->tables
->map('name')
->say
->completed
})->get;
# Load schemata from a hashref (e.g. pulled
# from a YAML/JSON/XML file or API)
$orm->load_from({ ... })
->then(sub {
$orm->apply_to($db)
})->then(sub {
say 'We have the following tables:';
$orm->tables
->map('name')
->say
->completed
})->get;
load_from
Loads schema, tables, types and any other available objects from a source - currently supports the following:
hashref
YAML file
directory of YAML files
You can call this multiple times to accumulate objects from various different sources.
Returns the current Database::Async::ORM instance.
METHODS - Internal
These are used by Database::Async::ORM and the precise API details may change in future.
populate_table
Populates a Database::Async::ORM::Table instance.
read_from
Reads data from a file or recursively from a base path.
SEE ALSO
AUTHOR
Tom Molesworth <TEAM@cpan.org>
LICENSE
Copyright Tom Molesworth 2011-2023. Licensed under the same terms as Perl itself.