NAME

DBIx::Class::TopoSort - The addition of topological sorting to DBIx::Class

SYNOPSIS

Without using TopoSort as a component:

my @toposorted_sourcenames = DBIx::Class::TopoSort->toposort($schema);

my @toposorted_sourcenames = DBIx::Class::TopoSort->toposort($schema, skip => {
        Artist => [qw/ first_album /],
});

Alternately, as a component - within your schema class:

__PACKAGE__->load_components('TopoSort');

Later:

my $schema = Your::App::Schema->connect(...);
my @toposorted_sourcenames = $schema->toposort();

If you have a cycle in your relationships

my @toposorted_sourcenames = $schema->toposort(
    skip => {
        Artist => [qw/ first_album /],
    },
);

DESCRIPTION

This adds the ability to return the list of sources (similar to "sources" in DBIx::Class::Schema) in topological-sorted order. This can be used either as a component or as an independent method.

TOPOLOGICAL SORT

A topological sort of the tables returns the list of tables such that any table with a foreign key relationship appears after any table it has a foreign key relationship to.

METHODS

Both methods may be used either as class methods of TopoSort or as methods of the schema (when TopoSort is loaded as a component). This class is not instantiable.

toposort($schema?, %opts?)

This is sugar for:

$self->toposort_graph(@_)->toposort();

Calling this method multiple times may return the list of source names in different order. Each order will conform to the gurantee described in the section on TOPOLOGICAL SORT.

This method will throw an error if there are any cycles in your tables. You will need to specify the skip parameter (described below) to break those cycles.

toposort_graph($schema?, %opts?)

This returns a Graph object with a vertex for every source and an edge for every foreign key relationship.

It takes the following parameters.

skip

This describes the list of relationships that should be ignored by the toposort algorithm. This is generally used if you have cycles in your schema (though it could possibly be useful in other ways, I guess). The value is a hashref. The keys of this hashref are source names and the values are arrays of relationship names.

skip => {
    Artist => [ qw/ first_album / ],
},

SEE ALSO

"toposort" in Graph

AUTHORS

  • Rob Kinyon <rob.kinyon@gmail.com>

LICENSE

Copyright (c) 2013 Rob Kinyon. All Rights Reserved. This is free software, you may use it and distribute it under the same terms as Perl itself.