Oracle
 sql >> Baza danych >  >> RDS >> Oracle

Jak napisać java.sql.Array do java.sql.SQLOutput w SQLData.writeSQL() dla Oracle

Oto, co zrobiłem, aby obejść ten problem. To nie jest ładne, ale działa.

Dodałem metodę w mojej klasie implementującą SQLData który odbiera java.sql.Connection i konfiguruje odpowiedni java.sql.ARRAY obiekty.

Coś takiego:

public class MyObject01 implements SQLData {
   private String value;
   private MyObject02[] details; // do note that details is a java array
   // ... also added getters and setters for these two properties

   private Array detailsArray;

   public void setupArrays(oracle.jdbc.OracleConnection oconn)
      throws SQLException
   {
       detailsArrays = oconn.createARRAY(MyObject02.ORACLE_OBJECT_ARRAY_NAME, getDetails());
       // MyObject02.ORACLE_OBJECT_ARRAY_NAME must be the name of the oracle "table of" type name
       // Also note that in Oracle you can't use JDBC's default createArray
       // since it's not supported. That's why you need to get a OracleConnection
       // instance here. 
   }       

   @Override
   public void writeSQL(Stream stream) throws SQLException {
       stream.writeString(getValue());
       stream.writeArray(detailsArray); // that's it
   }

   @Override
   public void readSQL(Stream stream) throws SQLException {
       setValue(stream.readString());
       Array array = stream.readArray();
       if (array != null) {
           setDetails((MyObject02[])array.getArray());
       }
   }

To pierwsza część.

Następnie PRZED użyciem tego obiektu w wywołaniu procedury wywołaj setupArrays metody na tym obiekcie. Przykład:

public class DB {
    public static String executeProc(Connection conn, MyObject01 obj)
        throws SQLException
    {
        CalllableStatement cs = conn.prepareCall(" { ? = call sch.proc(?) }");
        cs.registerOutParameter(1, Types.VARCHAR);
        obj.setupArrays((oracle.jdbc.Connection)conn);
        cs.setObject(2, obj, Types.STRUCT);
        cs.executeUpdate();
        String ret = cs.getString(1);
        cs.close();
        return ret;
    }
}

Oczywiście po połączeniu musisz poprawnie zarejestrować swoje typy:

Connection conn = DriverManager.getConnection("jdbc:oracle://localhost:1521/XE", "scott", "tiger" );
conn.getTypeMap().put(MyObject01.ORACLE_OBJECT_NAME, MyObject01.class);
conn.getTypeMap().put(MyObject02.ORACLE_OBJECT_NAME, MyObject02.class);
conn.getTypeMap().put(MyObject02.ORACLE_OBJECT_ARRAY_NAME, MyObject02[].class);

Mam nadzieję, że to pomoże.



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Odpowiednik Oracle „printf”

  2. Wywołanie procedury składowanej z kursorami zgłasza niepoprawny wyjątek nazwy kolumny

  3. Przypisanie kursora funkcji

  4. Przeanalizuj tabelę HTML za pomocą Oracle

  5. Jak stworzyć widok za pomocą akcji dynamicznej w Oracle APEX?