DOKK / manpages / debian 12 / libcatmandu-perl / Catmandu::Store::Multi.3pm.en
Catmandu::Store::Multi(3pm) User Contributed Perl Documentation Catmandu::Store::Multi(3pm)

Catmandu::Store::Multi - A store that adds data to multiple stores

    # On the Command line
    # Configure the Multi store with a catmandu.yml file
    $ cat catmandu.yml
    ---
    store:
      metadata1:
       package: DBI
       options:
          data_source: "DBI:mysql:database=catmandu"
      metadata2:
       package: ElasticSearch
       options:
           client: '1_0::Direct'
           index_name: catmandu
      multi:
       package: Multi
       options:
           stores:
               - metadata1
               - metadata2
    ...
    # Add a YAML record to the multi store
    $ catmandu import YAML to multi < data.yml
    # Extract all the records from the multi store as YAML
    $ catmandu export multi to YAML > data.yml
    # In Perl
    use Catmandu;
    my $store = Catmandu->store('Multi' , stores [
        Catmandu->store('DBI', data_source => 'DBI:mysql:database=catmandu') ,
        Catmandu->store('ElasticSearch', client => '1_0::Direct', index_name => 'catmandu') ,
    ]);
    $store->bag->each(sub {
        my $item = shift;
        printf "%s\n" , $item->{_id};
    });
    $store->bag->add({ _id => 1234 , foo => 'bar' , test => [qw(1 2 3 4)]});
    my $item = $store->bag->get('1234');
    $store->bag->delete('1234');

The Catmandu::Store::Multi is a combination of many Catmandu::Store-s as one access point. The Multi store inherits all the methods from Catmandu::Store.

By default, the Multi store tries to update records in all configured backend stores. Importing, exporting, delete and drop will be executed against all backend stores when possible.

Create a new Catmandu::Store::Multi.The "store" configuration parameter contains an array of references to Catmandu::Store-s based on their name in a configuration file or instances.

This Catmandu::Store implements:

Each Catmandu::Bag in this Catmandu::Store implements:

2023-03-03 perl v5.36.0