Title
DBR Schema and Data Browser
Synopsis
% dbr-browse conf=dbr.conf
% dbr-browse conf=foo.conf class=master
% dbr-browse conf=foo.conf pkeymax=50 dumpmax=25 highvar=300 highsamp=10
If you have not installed DBR yet:
% perl -I ../lib dbr-browse conf=bar.conf
Description
dbr-browse is a DBR tool that shows you database tables with DBR metadata mixed in. DBR metadata includes the translator type (e.g. UnixTime, Dollars, Enum, Percent), enumeration handles associated with an Enum field, and the forward and backward names of relationships to other tables via foreign keys.
At present, the dbr-admin tool is the preferred method for adding in DBR metadata. Developers will subsequently find dbr-browse a useful tool for coding the correct names in "table paths" when accessing data from a Record object, specifying key values to use with ResultSet's hasmap_single() and hashmap_multi() methods, and when expressing constraints for an Object where() method.
Use
Synopsis
SCHEMA> webshop
- Find Tables
-
TABLE> item 0) items 1) item_shipment 2) received_items
- Table Information
-
TABLE> 0 TABLE> products
- Field Value Stats
-
TABLE> 0 type TABLE> 0 type/product_id=432,654,765
- Sample Record Dumps
-
TABLE> 0 /item_id=1234 TABLE> 0 /product.brand.name=Ford,GM/type=coupe,wagon,suv TABLE> 0 /order.customer.lastname=Jones
General
The config file parameter establishes your access to a collection of databases.
Those databases that have been scanned will have schema data available.
The schemas will be listed and you will be prompted to enter the name of one.
Table view mode is now entered.
Your remaining inputs will be the name (or number) of a table to view.
A blank input will return to the schema prompt; blank input again will exit.
A '?' will list all tables, otherwise a list will be shown matching the input.
When presented with a list, enter the number for the item or key in the full name.
The number must be used if the table name is also a substring of other table names.
Command Arguments
- conf
-
The DBR config file. Required.
- class
-
By default, the "query" class database is queried. You may have other classes defined. The other typical class is "master", which is the read-write instance. default: query
- pkeymax
-
When sample data for a field is requested, this arg sets the maximum number of sample pkey values for the table that will be shown. default: 10
- dumpmax
-
When a field is not specified with a search expression, full records are dumped. This arg controls the maximum number of sample dumps shown. default: 10
- highvar
-
This is the threshold number of distinct values for a field that will truncate the values listing. Stands for "high variability" of field values. default: 200
- highsamp
-
If the values listing is truncated, this sets the number of sample values to display. default: 20
Field Value Stats
Getting a sample of table field values is very helpful when
getting to know a database.
A table or result index may be followed with a field specification.
If there are less than 200 (or highvar) distinct values in the field, each value
and the number of times it occurs will be listed.
If there are over 200 (or highvar) distinct values, a sampler of 20 (or highsamp) values
will be shown.
In any case, a sampler of up to 10 (or pkeymax) of the table's pkeys will be listed
with each of the values shown.
Multiple fields may be specified, separated by spaces, or "*" for
all the table's fields (handy for getting an idea of all the data in the table).
Full Record Dumps
If no field is specified with a search, a maximum of 10 (or dumpmax) records
will be shown.
Examples
examples/music/browse_test.sh
Technical Notes
The get_chunker() and related manual chunking is not required - DBR will do this for
us, but for large tables DBR simply has too much overhead when the scan covers the
entire table (such as getting stats on the number of records associated with each
one of 3 possible "status" field values).
4 POD Errors
The following errors were encountered while parsing the POD:
- Around line 426:
'=item' outside of any '=over'
- Around line 454:
You forgot a '=back' before '=head2'
- Around line 476:
'=item' outside of any '=over'
- Around line 516:
You forgot a '=back' before '=head2'