Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 6857591
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 27, 20262026-05-27T02:02:33+00:00 2026-05-27T02:02:33+00:00

I have a function that receives a query as parameter (as clob type) and

  • 0

I have a function that receives a query as parameter (as clob type) and ‘selects’ this query’s rows for returning. I need to use dbms_sql, because the query’s size is larger than 32kb (~150kb).

I’m stuck at point of fetching into result:

 -- execute immediate style (does not work with clob):
 EXECUTE IMMEDIATE large_query BULK COLLECT INTO V_TAB ;

 -- dbms_sql style:
 v_upperbound := CEIL(DBMS_LOB.GETLENGTH(large_query)/256);
 FOR i IN 1..v_upperbound
 LOOP
   v_sql(i) := DBMS_LOB.SUBSTR(large_query,256,((i-1)*256)+1);                            
 END LOOP;
 v_cur := DBMS_SQL.OPEN_CURSOR;
 DBMS_SQL.PARSE(v_cur, v_sql, 1, v_upperbound, FALSE, DBMS_SQL.NATIVE);
 v_ret := DBMS_SQL.EXECUTE(v_cur);

 -- NOW WHAT??

I’m in Oracle 9i/10g, so I can’t use dbms_slq.to_refcursor.

Any suggestions?

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-27T02:02:34+00:00Added an answer on May 27, 2026 at 2:02 am

    Here’s an example from the Oracle docs. Basically you need dbms_sql.fetch_rows and dbms_sql.column_value:

    CREATE TABLE multi_tab (num NUMBER, 
                            dat1 DATE, 
                            var VARCHAR2(24), 
                            dat2 DATE) 
    
    declare
      c       NUMBER;
      d       NUMBER;
      n_tab  DBMS_SQL.NUMBER_TABLE;
      d_tab1 DBMS_SQL.DATE_TABLE;
      v_tab  DBMS_SQL.VARCHAR2_TABLE;
      d_tab2 DBMS_SQL.DATE_TABLE;
      indx NUMBER := 10;
    BEGIN
    
      c := DBMS_SQL.OPEN_CURSOR;
      DBMS_SQL.PARSE(c, 'select * from multi_tab order by 1', DBMS_SQL.NATIVE);
    
      DBMS_SQL.DEFINE_ARRAY(c, 1, n_tab,  5, indx);
      DBMS_SQL.DEFINE_ARRAY(c, 2, d_tab1, 5, indx);
      DBMS_SQL.DEFINE_ARRAY(c, 3, v_tab,  5, indx);
      DBMS_SQL.DEFINE_ARRAY(c, 4, d_tab2, 5, indx);
    
      d := DBMS_SQL.EXECUTE(c);
    
      loop
        d := DBMS_SQL.FETCH_ROWS(c);
    
        DBMS_SQL.COLUMN_VALUE(c, 1, n_tab);
        DBMS_SQL.COLUMN_VALUE(c, 2, d_tab1);
        DBMS_SQL.COLUMN_VALUE(c, 3, v_tab);
        DBMS_SQL.COLUMN_VALUE(c, 4, d_tab2);
    
        EXIT WHEN d != 5;
      END LOOP;
    
      DBMS_SQL.CLOSE_CURSOR(c);
    
    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I have a WebMethod that recives HTML as parameter somthing like this: Public Function
I have a function that receives three different people objects and generates a new
I have a function that receives float** as an argument, and I tried to
So I have some function that receives N random 2D points. Is there any
I have a function that takes, amongst others, a parameter declared as int privateCount
I have a function that looks like this class NSNode { function insertAfter(NSNode $node)
I have a function that I use called sqlf(), it emulates prepared statements. For
Hey guys I have an ajax jquery function that receives data from a php
I have a table with a whole name. I have a function that receives
I have a plpgsql function that executes a query, but when i put an

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.