Can a procedure in Oracle return a result set? If so, it would seem that you're forced to deal with those results being returned in an array. Seems a bit heavy handed given that the DBI provides many faster ways to return results. Moreover, all rows will be squashed together...how do you know where one row stops and the next starts? Also, the calling of a procedure vs the calling of a function seems rather arbitrary. Is there some way to perhaps distinguish the two at run time? Perhaps inside of an eval? (i.e. try the name of the function as a stored procedure first...if it fails because it doesn't exist, then try it as a function) Other than that...cool idea. :)

thor

Feel the white light, the light within
Be your own disciple, fan the sparks of will
For all of us waiting, your kingdom will come

Update I forgot to mention...in your __run_procedure sub, you do croak "blah" unless ref $dbh. Your check will fail to detect an error if I call it like-a-so: sysdate(\1). It's not enough to check that $dbh is a reference...it has to be the right kind of reference.

In reply to Re: calling Oracle stored procedures by thor
in thread calling Oracle stored procedures by Thilosophy

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.