Provided by: libcatmandu-perl_1.2020-1_all 

NAME
Catmandu::Fix::add_to_store - add matching values to a store as a side effect
SYNOPSIS
# Add the current record to an SQLite database.
add_to_store(., DBI, data_source: "dbi:SQLite:path/data.sqlite")
# Add the journal field to a MongoDB database.
add_to_store(journal, MongoDB, database_name: catalog)
# Add all author values to a MongoDB database.
add_to_store(authors.*, MongoDB, database_name: catalog, bag: authors)
# Or, a much faster option: use a named store in a catmandu.yml file
#
# store:
# mydbi:
# package: DBI
# options:
# data_source: "dbi:SQLite:path/data.sqlite"
# mymongo:
# package: MongoDB
# options:
# database_name: catalog
add_to_store(., mydbi)
add_to_store(journal, mymongo)
add_to_store(authors.*, mymongo, bag: authors)
DESCRIPTION
add_to_store(PATH,STORE[,store_param: store_val, ...][,bag: bag_name])
Store a record or parts of a record in a Catmandu::Store. The values at the PATH will be stored as-is in
the database but should be hashes. If the value contains an '_id' field, then it will used as record
identifier in the database. If not, then a new '_id' field will be generated and added to the database
and original field (for later reference).
For instance this YAML input:
---
_id: 001
title: test
name: foo
---
_id: 002
title: test2
name: bar
with the fix:
add_to_store(., DBI, data_source: "dbi:SQLite:path/data.sqlite")
will create a path/data.sqlite SQLite database with two records. Each records contains the _id from the
input file and all the record fields.
For instance this YAML input:
---
title: test
name: foo
---
title: test2
name: bar
with the fix:
add_to_store(., DBI, data_source: "dbi:SQLite:path/data.sqlite")
will create a path/data.sqlite SQLite database with two records. Each records contains the a generated
_id and all the record fields. The current input stream will be updated to contain the generated _id.
Use Catmandu::Fix::lookup_in_store to lookup records in a Catmandu::Store based on an '_id' key.
DATABASE CONNECTIONS
For every call to a "add_to_store" a new database connection is created. It is much more effient to used
named stores in a "catmandu.yml" file. This file needs to contain all the connection parameters to the
database. E.g.
store:
mystore:
package: MongoDB
options:
database_name: mydata
The "catmandu.yml" file should be available in the same directory as where the "catmandu" command is
executed. Or, this directory can be set with the "-L" option:
$ catmandu -L /tmp/path convert ...
SEE ALSO
Catmandu::Fix , Catmandu::Fix::lookup_in_store
perl v5.36.0 2023-03-03 Catmandu::Fix::add_to_store(3pm)