Inhaltsverzeichnis
一、手动编写Java存储过程/函数
二、使用外部class文件装载创建
三、使用loadjava命令远程装载并创建
Heim Datenbank MySQL-Tutorial 在Oracle中调用Java Source 的方法

在Oracle中调用Java Source 的方法

Jun 07, 2016 pm 03:51 PM
java oracle source 方法 调用

通常有三种方法来创建java存储过程。 一、手动编写Java存储过程/函数 利用SQL脚本代码,手动编写可供Oracle调用的Java存储过程或函数,和普通的存储过程/函数创建方法类,以存储过程为例,语法如下: CREATE OR REPLACE AND COMPILE JAVA SOURCE NAMED java_

通常有三种方法来创建java存储过程。

一、手动编写Java存储过程/函数

利用SQL脚本代码,手动编写可供Oracle调用的Java存储过程或函数,和普通的存储过程/函数创建方法类似,以存储过程为例,语法如下:

CREATE OR REPLACE AND COMPILE JAVA SOURCE NAMED java_soure_name 

AS

示例:创建一个简单的Hello World输出过程,调用JavaSource实现

  1. 创建Java Source

CREATE OR REPLACE AND COMPILE JAVA SOURCE NAMED OracleJavaProc
AS
public class OracleJavaProc
{
  public static void main(String[] args) 
	{
		System.out.println("Hello World!");
	}
}
Nach dem Login kopieren

2.  创建存储过程 ,调用Java Source

CREATE OR REPLACE PROCEDURE testoraclejava
AS
LANGUAGE JAVA
NAME 'OracleJavaProc.main(java.lang.String [])';
Nach dem Login kopieren

3.  调用存储过程

begin
  dbms_java.set_output(2000); ---设置Java输出缓冲区大小,否则无法输出数据
  testoraclejava;             ---调用存储过程
end;
Nach dem Login kopieren
输出结果:Hello World!

二、使用外部class文件装载创建

将外部编译好的Java类文件(*.class)通过命令导入到数据库服务器中,实现Java存储过程的创建。

  1. 首先,既然要外部文件导入,那么就需要建立一个目录来存放*.class文件
  2. 其次,将编译好的class文件导入到服务器中
  3. 创建存储过程,调用导入的Java Source

创建目录和Java Source

SQL> create or   replace   directory   test_dir   as  'd:/oracle';  
 
目录已创建。  
 
SQL> create or replace java class using bfile(test_dir, 'OracleJavaProc.class')  
  2  /  
 
Java 已创建。 
Nach dem Login kopieren

TIPS:如果第二步时出现:ORA-29516: Aurora 断言失败: Assertion failure at eox.c:359
Uncaught exception System error:   java/lang/UnsupportedClassVersionError 的错误,机器装了多个Java版本,oracle的Java版本低于环境变量设置的版本。

解决办法:用$ORACLE_HOME/jdk/bin/javac 重新编译java文件。

三、使用loadjava命令远程装载并创建

  • 先创建一个类:

import java.sql.*;  
import oracle.jdbc.*;  
 
public class OracleJavaProc {  
   //Insert a record to the database.  
   public static void insertRecord(int id, String name, int age ,String xman_id) {  
      System.out.println("Inserting new records for EMP...");  
      try 
	  {
		  Connection conn = DriverManager.getConnection("jdbc:default:connection:");  
          String sql = "INSERT INTO emp " +  
					   "(ID,NAME,SALARY,XMAN_ID) " +  
					   "VALUES(?,?,?,?)";
		  PreparedStatement pstmt = conn.prepareStatement(sql);  
		  pstmt.setInt(1,id);
		  pstmt.setString(2,name);
		  pstmt.setInt(3,age);
		  pstmt.setString(4,xman_id);
		  pstmt.executeUpdate();  
		  pstmt.close();
	  } 
	  catch(SQLException e) 
	  {
		  System.err.println("ERROR! Inserting record: " + e.getMessage());
	  }  
   }
   //Select a reords from database
   public static boolean recordQuery(int id) {
	   System.out.println("Querying records from EMP...");
	   try
	   {
		   Connection conn = DriverManager.getConnection("jdbc:default:connection:");
		   String sql = "SELECT * FROM emp WHERE id = ?";
		   PreparedStatement pstmt = conn.prepareStatement(sql);
		   pstmt.setInt(1,id);
		   ResultSet rs = pstmt.executeQuery();

		   while(rs.next()) {
			   System.out.println(rs.getInt(1)+"\t"+rs.getString(2)+"\t"+
								  rs.getInt(3)+"\t"+rs.getString(4));
		   }
		   return true;
	   }
	   catch (SQLException e)
	   {
		   System.err.println("ERROR! Querying record: " + e.getMessage());
		   return false;
	   }
   }
} 
Nach dem Login kopieren
  • 使用loadjava命令将其装载到服务器端并编译:

D:\Oracle>loadjava -u hbi/hbi@orcl -v -resolve OracleJavaProc.java

arguments: '-u' 'hbi/hbi@orcl' '-v' '-resolve' 'OracleJavaProc.java'

creating : source OracleJavaProc

loading  : source OracleJavaProc

resolving: source OracleJavaProc

Classes Loaded: 0

Resources Loaded: 0

Sources Loaded: 1

Published Interfaces: 0

Classes generated: 0

Classes skipped: 0

Synonyms Created: 0

Errors: 0

  • 创建存储过程和函数:

创建存储过程,实现数据插入:

create or replace procedure INSERT_RECORD(V_ID      number,
                                          V_NAME    varchar2,
                                          V_SALARY  number,
                                          V_XMAN_ID varchar2) as
language java name 'OracleJavaProc.insertRecord(int,java.lang.String,int,java.lang.String)';
Nach dem Login kopieren
创建函数,实现数据查询:

create or replace function QUERY_TABLE(v_id number) return number 
as
  language java name 'OracleJavaProc.recordQuery(int) return int';
Nach dem Login kopieren
  • 测试一下结果:

SQL> set serveroutput on size 2000  
SQL> call dbms_java.set_output(2000);  
 
调用完成。  
 
SQL> execute add_salgrade(29, 'Charles', 5000, '029');  
Inserting new records for EMP...
 
PL/SQL 过程已成功完成。
Nach dem Login kopieren

  在Oracle中调用Java Source 的方法

  • 更新你已经编写的Java存储过程

修改好Java源代码后,先dropjava ,再loadjava。

D:\Oracle>dropjava -u hbi/hbi@orcl -v OracleJavaProc
dropping: source OracleJavaProc

D:\Oracle>loadjava -u hbi/hbi@orcl -v -resolve OracleJavaProc.java
arguments: '-u' 'hbi/hbi@orcl' '-v' '-resolve' 'OracleJavaProc.java'
creating : source OracleJavaProc
loading  : source OracleJavaProc
resolving: source OracleJavaProc
Classes Loaded: 0
Resources Loaded: 0
Sources Loaded: 1
Published Interfaces: 0
Classes generated: 0
Classes skipped: 0
Synonyms Created: 0
Errors: 0


Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

So fügen Sie Festplatten in Oracle RAC hinzu und ersetzen Sie So fügen Sie Festplatten in Oracle RAC hinzu und ersetzen Sie Apr 11, 2025 pm 05:39 PM

Oracle RAC -Festplatte Neue und Ersatzvorgänge: Fügen Sie Festplatten hinzu: Fügen Sie neue Festplatten hinzu, erstellen Sie ASM -Disk -Gruppen, fügen Sie Cluster hinzu, verschieben Sie Datendateien. Festplatte ersetzen: Identifizieren Sie die fehlgeschlagene Festplatte, schließen Sie die Festplattengruppe, ersetzen Sie die Festplatte, öffnen Sie die Festplattengruppe, reparieren Sie die fehlgeschlagene Festplatte und verschieben Sie die Datendateien.

Oracle, um zu sehen, welche Prozesse über Datenbanktabellen verwiesen werden Oracle, um zu sehen, welche Prozesse über Datenbanktabellen verwiesen werden Apr 11, 2025 pm 03:24 PM

Eine Reise zur Oracle -Tabelle Referenzierter Prozess: Direkte Methode: Verwenden Sie die All_Dependencies oder die Ansicht der Datenwörterbuchansicht von User_Dependenzen, um gespeicherte Prozeduren, Funktionen und Auslöser für referenzierte Tabellen zu finden. Erweiterte Technologie: Schreiben von PL/SQL -Verfahren, um rekursiv Abhängigkeiten zu finden, jedoch zu hohen Kosten. Dynamische Referenz: Die Verwendung dynamischer SQL -Referenzen kann nicht nach der obigen Methode erkannt werden und eine weitere Analyse ist erforderlich. Leistungsoptimierung: Wählen Sie die entsprechende Ansicht (All_Dependencies oder User_Dependencies) aus und fügen Sie den Index hinzu. Gute Gewohnheiten: Befolgen Sie die Namenskonventionen, modulare Code und Kommentare, um zu verhindern, dass Abhängigkeiten feststellen.

Zusammenfassung der Grundkenntnisse der Oracle -Datenbank Zusammenfassung der Grundkenntnisse der Oracle -Datenbank Apr 11, 2025 pm 06:33 PM

Die Oracle-Datenbank ist ein zuverlässiges, skalierbares und featurereiches relationales Datenbankverwaltungssystem (RDBMS). Die Architektur folgt dem Client-Server-Modell, einschließlich serverseitiger Komponenten (Oracle Net), Instanzen, gemeinsamen Speicherbereiche (SGAs), Hintergrundprozessen und Datenbankdateien, die Daten speichern. Zu den grundlegenden Konzepten gehören Tabellen, Zeilen, Spalten, Primärschlüssel, Fremdschlüssel, Indizes und Cursoren. Die Datenbank ist bekannt für ihre Vorteile wie hohe Verfügbarkeit, Big -Data -Unterstützung, umfangreiche Funktionen, starke Sicherheit und Benutzerfreundlichkeit.

So ändern Sie Oracle -Zeichensatz So ändern Sie Oracle -Zeichensatz Apr 11, 2025 pm 06:57 PM

Um den Oracle -Zeichensatz zu ändern, müssen Sie: die Datenbank sichern; Ändern Sie die Zeichensatzeinstellungen in der init.ora -Datei; Starten Sie die Datenbank neu; Ändern Sie vorhandene Tabellen und Spalten, um den neuen Zeichensatz zu verwenden. Laden Sie die Daten neu; Ändern Sie den Datenbanklink (optional).

Wie man Orakel wiedergegeben Wie man Orakel wiedergegeben Apr 11, 2025 pm 07:33 PM

Oracle bietet mehrere Deduplication -Abfragemethoden: Das bestimmte Schlüsselwort gibt für jede Spalte einen eindeutigen Wert zurück. Die Gruppe nach Klausel gruppiert die Ergebnisse und gibt für jede Gruppe einen nicht repetitiven Wert zurück. Das eindeutige Schlüsselwort wird verwendet, um einen Index mit nur eindeutigen Zeilen zu erstellen, und das Abfragen des Index wird automatisch dedupliziert. Die Funktion row_number () weist eindeutige Zahlen und filtert Ergebnisse aus, die nur Zeile 1 enthalten. Die Funktion min () oder max () gibt nicht repetitive Werte einer numerischen Spalte zurück. Der Schnittbetreiber gibt die gemeinsamen Werte der beiden Ergebnissätze zurück (keine Duplikate).

Wie man Zeit in Oracle bekommt Wie man Zeit in Oracle bekommt Apr 11, 2025 pm 08:09 PM

Es gibt die folgenden Methoden, um Zeit in Oracle zu bekommen: current_timestamp: Gibt die aktuelle Systemzeit genau auf Sekunden zurück. SYSTIMESTAMP: genauer als Current_Timestamp, für Nanosekunden. SYSDATE: Gibt das aktuelle Systemdatum mit Ausnahme des Zeitteils zurück. To_char (sysdate, 'yyy-mm-dd hh24: mi: ss'): konvertiert das aktuelle Systemdatum und die Uhrzeit in ein bestimmtes Format. Extrakt: Extrahiert einen bestimmten Teil aus einem Zeitwert wie einem Jahr, Monat oder Stunde.

So sichern Sie Oracle -Datenbanken automatisch So sichern Sie Oracle -Datenbanken automatisch Apr 11, 2025 pm 08:12 PM

Befolgen Sie die folgenden Schritte, um eine automatische Sicherung in Oracle zu ermöglichen: 1. Erstellen Sie einen Sicherungsplan. 2. Aktivieren Sie einen Backup -Plan; 3. Planen Sie das Sicherungsfenster. Automatische Backups stellen automatisch eine Verbindung zur Datenbank her, identifizieren Änderungen, erstellen inkrementelle Sicherungen, speichern Backups und saubere alte Backups, wodurch die Belastung des Managements reduziert wird, den Datenschutz verbessert, die Versionskontrolle, die Optimierung der Leistung und die Unterstützung der Einhaltung der Einhaltung der Vorschriften, verbessert.

So überprüfen Sie die Tabellenraumgröße von Oracle So überprüfen Sie die Tabellenraumgröße von Oracle Apr 11, 2025 pm 08:15 PM

Um die Oracle -Tablespace -Größe abzufragen, führen Sie die folgenden Schritte aus: Bestimmen Sie den Namen Tablespace, indem Sie die Abfrage ausführen: Wählen Sie Tablespace_Name aus dba_tablespaces. Abfragen Sie die Tablespace -Größe durch Ausführen der Abfrage: Summe (Bytes) als Total_Size, sum (bytes_free) als verfügbare_space, sum

See all articles