I've got a poorly-implemented database that I'm saddled with for at least another 4-N months. I would like to remove the SQL from within the Perl script to "some other place". Except, part of the SQL is dynamically generated. Right now, it looks something like:
my $dyn_sql_maker = Some::Class->new( type => $cgi->param('type'), id => $cgi->param('id'), # etc ... ); my $sql = ''; $sql .= $dyn_sql_maker->select_clause . " Report-specific static SQL here "; $sql .= $dyn_sql_maker->from_clause . " Report-specific static SQL here "; $sql .= $dyn_sql_maker->where_clause . " Report-specific static SQL here "; $sql .= $dyn_sql_maker->groupby_clause . " Report-specific static SQL here "; # Do something with the SQL

The static stuff is based solely on which report you're running and not your type nor your id. The dynamic stuff is based solely on your type and id, but not which report you're running. And, these are 5-8 table joins with craziness heavily involved, so I can't use Class::DBI (Which is actually figuring into my resdesign of the schema ... I'm designing it to be able to use Class::DBI.)

Is there a module out there that will fit my needs? I'd rather not write one, if I didn't have to.

------
We are the carpenters and bricklayers of the Information Age.

The idea is a little like C++ templates, except not quite so brain-meltingly complicated. -- TheDamian, Exegesis 6

... strings and arrays will suffice. As they are easily available as native data types in any sane language, ... - blokhead, speaking on evolutionary algorithms

Please remember that I'm crufty and crochety. All opinions are purely mine and all code is untested, unless otherwise specified.


In reply to Navigating the plethora of SQL modules by dragonchild

Title:
Use:  <p> text here (a paragraph) </p>
and:  <code> code here </code>
to format your post, it's "PerlMonks-approved HTML":



  • Posts are HTML formatted. Put <p> </p> tags around your paragraphs. Put <code> </code> tags around your code and data!
  • Titles consisting of a single word are discouraged, and in most cases are disallowed outright.
  • Read Where should I post X? if you're not absolutely sure you're posting in the right place.
  • Please read these before you post! —
  • Posts may use any of the Perl Monks Approved HTML tags:
    a, abbr, b, big, blockquote, br, caption, center, col, colgroup, dd, del, details, div, dl, dt, em, font, h1, h2, h3, h4, h5, h6, hr, i, ins, li, ol, p, pre, readmore, small, span, spoiler, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, tr, tt, u, ul, wbr
  • You may need to use entities for some characters, as follows. (Exception: Within code tags, you can put the characters literally.)
            For:     Use:
    & &amp;
    < &lt;
    > &gt;
    [ &#91;
    ] &#93;
  • Link using PerlMonks shortcuts! What shortcuts can I use for linking?
  • See Writeup Formatting Tips and other pages linked from there for more info.