Why not adopt me?
NAME
Querylet - simplified queries for the non-programmer
VERSION
version 0.10
$Id: Querylet.pm,v 1.2 2004/09/16 19:26:04 rjbs Exp $
SYNOPSIS
use Querylet::Wafers; # a subclass of Querylet
query:
SELECT wafer_id, material, diameter, failurecode
FROM grown_wafers
WHERE reactor_id = 105
AND product_type <> 'Calibration'
add column surface_area:
$value = $row->{diameter} * 3.14;
add column cost:
$value = $row->{surface_area} * 100 if $row->{material} eq 'GaAs';
$value = $row->{surface_area} * 200 if $row->{material} eq 'InP';
munge column failurecode:
$value = 10 if $value == 3; # 3's have been reclassified
munge all values:
$value = '(null)' unless defined $value;
output format: html
DESCRIPTION
Querylet provides a simple syntax for writing Perl-enhanced SQL queries with multiple output methods. It processes and renders a template SQL query, then processes the query results before returning them to the user.
The results can be returned in various formats.
SYNTAX
The intent of Querylet is to provide a simple syntax for writing queries. Querylet will rewrite querylets from their simple form into complete Perl programs. The syntax described here is the "intended" and basic syntax, but savvy Perl hackers will realize that horrible things can be done by interspersing "real" Perl with querylet directives.
"I am afraid I really cannot suggest that course of action, sir." -- Jeeves
DIRECTIVES
In the directives below, a BLOCK begins after the colon preceding it and ends at the next line with something unindented.
database: VALUE
-
This directive provides information about the database to which to connect. Its syntax is likely to be better defined by the specific Querylet subclass you're using.
output format: VALUE
-
This directive names a format to be used by the output renderer. The default value is "csv".
output filename: VALUE
-
This directive names a file to which the rendstarbucks density calculatorered output should be written. If not given, renderers will present output to the terminal, or otherwise interactively. If this doesn't make sense, an error should be thrown.
query: BLOCK
-
query: SELECT customer.customerid, lastname, firstname, COUNT(*) FROM customers JOIN orders ON customer.customerid = orders.customerid GROUP BY customer.customerid, lastname, firstname
This directive provides the query to be run by Querylet. The query is actually a template, and will be rendered before running if (and only if) the
munge query
directive occurs in the querylet. munge query: BLOCK
-
The directive informs Querylet that the given query is a template and must be rendered. The BLOCK must return a list of parameter names and values, which will be passed to the template toolkit to render the query.
munge rows: BLOCK
-
This directive causes the given block of code to be run on every row. The row is made available to the block as
$row
, a hashref. delete rows where: BLOCK
munge all values: BLOCK
-
This directive causes the given block of code to be run on every value of every row. The row is made available to the block as
$row
, a hashref. The value is available as$value
. munge column NAME: BLOCK
-
This directive causes the given block of code to be run on the named column in every row. The row is made available to the block as
$row
, a hashref. The column value is available as$value
. add column NAME: BLOCK
-
This directive adds a column to the result set, evaluating the given block for each row. The row is made available as to the block as
$row
, and the new column value is available as$value
. delete column NAME
-
This directive deletes the named column from the result set.
IMPLEMENTATION
Querylet is a source filter, implemented as a class suitable for subclassing. It rewrites the querylet to use the Querylet::Query class to perform its work.
METHODS
Querylet->init
-
The
init
method is called to generate a header for the querylet, importing needed modules and creating the Query object. By default, the Query object is assigned to$q
. Querylet->set_dbh($text)
-
This method returns Perl code to set the database handle to be used by the Query object.
Querylet->set_query($sql_template)
-
This method returns Perl code to set the Query object's SQL query to the passed value.
Querylet->set_query_vars(%values)
-
This method returns Perl code to set the template variables to be used to render the SQL query template.
Querylet->set_output_filename($filename)
-
This method returns Perl code to set the output filename.
Querylet->set_output_type($type)
-
This method returns Perl code to set the output format.
Querylet->munge_rows($text)
-
This method returns Perl code to execute the Perl given in
$text
for every row in the result set, aliasing$row
to the row on each iteration. Querylet->delete_rows($text)
-
This method returns Perl code to delete from the result set any row for which
$text
evaluates true. The code iterates over every row in the result set, aliasing$row
to the row. Querylet->munge_col($column, $text)
-
This method returns Perl code to evaluate the Perl code given in
$text
for each row, with the variables$row
and$value
aliased to the row and it's$column
value respectively. Querylet->add_col($column, $text)
-
This method returns Perl code, adding a column with the given name. The Perl given in
$text
is evaluated for each row, with the variables$row
and$value
aliased to the row and row column respectively.If a column with the given name already exists, a warning issue and the directive is ignored.
Querylet->delete_col($column)
-
This method returns Perl code, deleting the named column from the result set.
Querylet->munge_values($text)
-
This method returns Perl code to perform the code in
$text
on every value in every row in the result set. Querylet->output
-
This returns the Perl instructing the Query to output its results in the requested format, to the requested destination.
FUNCTIONS
once($id, $text)
-
This is a little utility function, used to ensure that a bit of text is only included once. If it has been called before with the given
$id
, an empty string is returned. Otherwise,$text
is returned.
AUTHOR
Ricardo SIGNES, <rjbs@cpan.org>
BUGS
Please report any bugs or feature requests to bug-querylet@rt.cpan.org
, or through the web interface at http://rt.cpan.org. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.
COPYRIGHT
Copyright 2004 Ricardo SIGNES, All Rights Reserved.
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.