sql >> Databáze >  >> RDS >> Oracle

Groovy Oracle Stored Proc - neplatný index sloupců

Následující kód vám může pomoci získat proměnnou SYS_REFCURSOR z anonymního bloku Oracle.

Měli bychom se zaměřit na několik klíčových detailů:

  1. Třída groovy.sql.Sql nemá odpovídající OutParameter a uděláme to ručně jako CURSOR_PARAMETER a předejte jej sql.call metoda
  2. Zvažte, že blok začíná {call DECLARE a končí END } bez středníku za END. Jinak můžeme získat špatně rozpoznatelnou SQLException v obličeji.
  3. Otazníky ? uvnitř sqlString jsou místa pro vazby parametrů. Vazby jsou vytvořeny v přirozeném pořadí a přebírají hodnoty z parametersList .
    • V tomto příkladu máme jedinou vazbu, tedy ? váže se s CURSOR_PARAMETER s hodnotou OUT parametr předávaného typu;
  4. Po sql.call existuje pouze jeden vstup do uzavření a ResultSet rs zadejte řádky kurzoru my_cur deklarováno v anonymním bloku.
  5. Můžeme zjednodušit sqlString pomocí funkce vracející SYS_REFCURSOR místo procedury s OUT parametr. Mohlo by to tedy vypadat takto "{call BEGIN ? := MY_FUNC(); END}" nebo dokonce "{? = call MY_FUNC()}"
import groovy.sql.OutParameter
import groovy.sql.Sql
import oracle.jdbc.OracleTypes

import java.sql.ResultSet

def driver = 'oracle.jdbc.driver.OracleDriver'
def sql = Sql.newInstance('jdbc:oracle:thin:@my-server:1521:XXX', 'usr', 'psw', driver)

// special OutParameter for cursor type
OutParameter CURSOR_PARAMETER = new OutParameter() {
    public int getType() {
        return OracleTypes.CURSOR;
    }
};

// look at some ceremonial wrappers around anonymous block
String sqlString = """{call
    DECLARE
      my_cur SYS_REFCURSOR;
    BEGIN
        STORED_PROCEDURE_NAME(my_cur);
        ? := my_cur;
    END
}
""";

// the order of elements matches the order of bindings
def parametersList = [CURSOR_PARAMETER];


// rs contains the result set of cursor my_cur
sql.call(sqlString, parametersList) { ResultSet rs ->
  while (rs.next()) {
      println rs.getString("my_column")
  }
};

P.S. A děkuji za otázku.




  1. Fragmentace tabulek Wordpress a MySQL

  2. Předání seznamu parametrů SQL v psycopg2

  3. Převod dotazu Oracle na uživatelem definované typy v pl/sql

  4. Dotaz MySQL je u velkých dat bolestivě pomalý