Oracle
 sql >> डेटाबेस >  >> RDS >> Oracle

जावा प्रोग्राम में जावा संग्रहीत कार्यविधि कॉलिंग

एक मान वापस करने के लिए आपको इसे एक कार्य करने की आवश्यकता है, न कि एक प्रक्रिया:

  public static String getBreweryInfo (int Raz_ID) 
  throws SQLException 
  { 
    String sql = 
      "SELECT Nosaukums FROM Alus_razotaji WHERE ID = ?";//vaicajums
    try {
      Connection conn = DriverManager.getConnection("jdbc:default:connection:");
      PreparedStatement apstmt = conn.prepareStatement(sql);
      apstmt.setInt(1, Raz_ID); 
      ResultSet rset = apstmt.executeQuery();// SQL vaicājuma izpildīšana

      if (rset.next()) {
          return rset.getString(1);
      } 
    }
    catch (SQLException e) {
      System.err.println(e.getMessage()); //Kļūdu izvadīsana
    } 
    finally {
      rset.close();
      apstmt.close(); //Savienojuma aizvēršana
    } 
  }

तब आपका पैकेज बन जाता है:

CREATE OR REPLACE PACKAGE BODY BeerBeer AS
  FUNCTION getBreweryInfo(Raz_ID number) RETURN varchar2 AS Language Java
  NAME 'BeerBeer.getBreweryInfo(int) return java.lang.String';
END BeerBeer;

और आप इसे कुछ इस तरह कहते हैं:

        String SQL = "{CALL ? = BeerBeer.getBreweryInfo (?)}";
        stmt = conn.prepareCall(SQL);
        int Raz_ID = 4;
        stmt.registerOutParameter(1, java.sql.Types.VARCHAR);
        stmt.setInt(2, Raz_ID);
        System.out.println("Izpildam JAVA glabajamo proceduru ...");
        // Vaicājuma izpilde
        stmt.execute();
        //Izgustam Alus_razotaja nosaukumu ar getXXX metodi.
        String Razotajs = stmt.getString(1);

ध्यान दें कि आउट पैरामीटर अब इंडेक्स 1 है क्योंकि यह फ़ंक्शन से रिटर्न है, इसलिए आपके द्वारा पास किया जाने वाला मान अब इंडेक्स 2 है। सभी का परीक्षण नहीं किया गया है...



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. nhibernate, Oracle में कॉल फ़ंक्शन जो sys refcursor लौटाता है

  2. Oracle तालिका/स्तंभ/सूचकांक नाम 30 वर्णों तक सीमित क्यों हैं?

  3. Oracle अनुक्रम मान का आदेश नहीं दिया गया है

  4. GI 12.2 अपग्रेड के लिए ASM में VOTE डिस्कग्रुप बढ़ाएँ

  5. लूप के लिए Oracle का उपयोग करके कर्सर से डेटा कैसे प्राप्त करें