NAME
File::Sticker::Database - write info to database
VERSION
version 1.0603
SYNOPSIS
use File::Sticker::Database;
my $db = File::Sticker::Database->new(%args);
$db->write_meta(%args);
DESCRIPTION
This will write meta-data from files in various formats, and standardize it to a common nomenclature.
DEBUGGING
whoami
Used for debugging info
METHODS
new
Create a new object, setting global values for the object.
my $obj = File::Sticker::Database->new(
dbname=>$dbname,
wanted_fields=>\%wanted_fields,
field_order=>\@field_order,
primary_table=>$primary_table,
);
do_connect
Connect to the database if not connected already.
create_tables
Create the tables for the database. Give them all prefixes so that multiple setups can use the same database.
do_disconnect
Disconnect from the database
start_transaction
Start a transaction.
commit
Commit a pending transaction.
$self->commit();
get_file_id
Get the fileid of the given file
my $fileid = $self->get_file_id($filename);
get_file_meta
Get the meta-data for a single file.
$meta = $self->get_file_meta($file);
get_all_files
Return a list of all the files in the database.
my @files = @{$db->get_all_files()};
get_all_tags
Return a list of all the tags from the appropriate "deep*" table.
my @tags = @{$db->get_all_tags()};
query_by_tags
Use +tag -tag nomenclature for searching the database for matching files. If the *info table exists, uses that, otherwise, it uses the "tagfield" in the primary table.
delete_file_from_db
Delete the record for one file from the database
$db->delete_file_from_db($filename);
add_meta_to_db
Add the given file info to the database.
$db->add_meta_to_db($filename, %meta);
Helper Functions
Private interface.
_deep_table_name
Return the name of the given deep_* table.
_do_one_col_query
Do a SELECT query, and return the first column of results. This is a freeform query, so the caller must be careful to formulate it correctly.
my $results = $self->_do_one_col_query($query);
_prepare
Prepare and cache prepared queries.
my $sth = $self->_prepare($q);
BUGS
Please report any bugs or feature requests to the author.