sql >> Database >  >> RDS >> Oracle

Hoe gegevens uit een pl/sql-functie te halen als een parameter meer dan één waarde heeft in functie met enkele parameters?

Met enigszins beperkte informatie is het onderstaande wat ik heb bedacht. Ik heb nog steeds geen idee wat er gebeurt met uw STATIC Cursor die u in uw vraag noemde, is gedefinieerd in uw f_process_data() Functie. Omdat ik de volledige code in deze functie niet ken, heb ik gewoon mijn eigen code geschreven en de CURSOR gedeclareerd als SYS_REFCURSOR, want dat is wat de functie retourneert.

Laat het me weten als dit werkt of als ik belangrijke informatie mis. Ik heb het gevoel dat ik cruciale informatie mis om je een bruikbare oplossing te bieden.

De mock-uptabel die ik met de naam Producten heb gemaakt, bevat de volgende kolommen en gegevens. Zie afbeelding.

DECLARE

  /* Store Ref Cursor returned by f_process_data() Function */
  v_result_cursor   SYS_REFCURSOR;

  /* Declare Record so we can store the data FETCHed from the Cursor */
  rec_products      products%ROWTYPE;

  /* Declare a couple Product Variables for Proof of Concept */
  v_sausage         NUMBER;
  v_ham             NUMBER;

  /* Store output */
  n_id              NUMBER;
  v_id_product      VARCHAR2(100);

  /* Declare Type of TABLE NUMBER */
  TYPE  nt_type IS TABLE OF NUMBER;

  /* Create Array/Table/Collection of type nt_type to store product ids */
  nt_product_ids    nt_type;

  /* Returns a Ref Cursor based on the product_id used as Input to this function */
  FUNCTION f_process_data(p_id_process IN NUMBER, p_id_product IN NUMBER)
  RETURN SYS_REFCURSOR
  AS
    /* Declare Ref Cursor that will be Returned */
    rc_result_cursor   SYS_REFCURSOR;    

  BEGIN 
    /* Open Ref Cursor based on Product ID parameter */
    OPEN rc_result_cursor FOR SELECT * FROM products WHERE item_id = p_id_product;

    RETURN rc_result_cursor;

  END f_process_data
  ;

BEGIN

  /* Set Product Variables to IDs */
  v_sausage       := 2002;
  v_ham           := 2009;

  /* Store product ids into a Number Table so we can Loop thru it */
  nt_product_ids  :=  nt_type (v_sausage,v_ham);

  FOR r IN nt_product_ids.FIRST .. nt_product_ids.LAST
  LOOP
    /* Get Ref Cursor using SINGLE Product ID */
    v_result_cursor := f_process_data(1, nt_product_ids(r));

    LOOP

    FETCH v_result_cursor INTO rec_products;

    n_id            :=  rec_products.item_id;
    v_id_product    :=  rec_products.item;

    EXIT WHEN v_result_cursor%NOTFOUND;

    dbms_output.put_line('Product_id: ' || n_id);
    dbms_output.put_line('Product: ' || v_id_product);  

    END LOOP; /* Cursor Loop */

    /* Close Cursor */
    CLOSE v_result_cursor;

  END LOOP; /* Product IDs Loop */

EXCEPTION WHEN OTHERS
  THEN CLOSE v_result_cursor;

END;



  1. MySQL longtext analoog in Microsoft SQL?

  2. Hoe kan ik JDBC gebruiken om schema's van de ene database naar de andere te kopiëren zonder Apache DDLUtils te gebruiken?

  3. MySQL:eenvoudige manier om een ​​waarde van een int-veld te wisselen

  4. Maak een vervolgkeuzelijst van waarde in database php