sqlplus commands in java ausführen

guguli

Bekanntes Mitglied
Hallo zusammen,

ich möchte gerne meine .sql file mit einem Java Programm in einer oracle DB ausführen.
Mein Java Code sieht so aus:
Code:
import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;

public class DBScriptRunner {
   public static void main(String[] args) {
       try {
           String pathname = args[0];
           System.out.println("path name: " +pathname);
           executeScript(pathname);
       } catch (IOException e) {
           e.printStackTrace();
       } catch (SQLException e) {
           e.printStackTrace();
       }
   }

   static void executeScript(String scriptFilePath) throws IOException, SQLException {
       // initialize script path
       // String scriptFilePath = "e:/script.sql";
       BufferedReader reader = null;
       Connection con = null;
       Statement statement = null;
       try {
           // load driver class for mysql
           Class.forName("oracle.jdbc.driver.OracleDriver");
           // create connection
           con = DriverManager.getConnection("jdbc:oracle:thin:@//host-name:1521/romdb", "user",
                   "pwd");
           statement = con.createStatement();
           // initialize file reader
           reader = new BufferedReader(new FileReader(scriptFilePath));
           String line = null;
           // read script line by line
           while ((line = reader.readLine()) != null) {
               // execute query
               if (line.startsWith("--")|| line.isEmpty()) {
                   System.out.println("comment line or empty line: " + line);
               } else {
                   System.out.println("Line: " + line);
                   statement.execute(line);
               }

           }
       } catch (Exception e) {
           System.out.println("*** Error : "+e.toString());  
            System.out.println("*** ");  
            System.out.println("*** Error : ");  
           e.printStackTrace();
       } finally {
           // close file reader
           if (reader != null) {
               reader.close();
           }
           // close db connection
           if (con != null) {
               con.close();
           }
       }
   }
}

das Probelm ist aber dass mein .sql file sqlplus command wie SET DEFINE OFF; hat,
und wenn ich mein Code ausführe dann bekomme ich folgende Fehlermeldung:

Code:
java.sql.SQLSyntaxErrorException: ORA-00922: missing or invalid option

        at oracle.jdbc.driver.T4CTTIoer11.processError(T4CTTIoer11.java:494)
        at oracle.jdbc.driver.T4CTTIoer11.processError(T4CTTIoer11.java:446)
        at oracle.jdbc.driver.T4C8Oall.processError(T4C8Oall.java:1052)
        at oracle.jdbc.driver.T4CTTIfun.receive(T4CTTIfun.java:537)
        at oracle.jdbc.driver.T4CTTIfun.doRPC(T4CTTIfun.java:255)
        at oracle.jdbc.driver.T4C8Oall.doOALL(T4C8Oall.java:610)
        at oracle.jdbc.driver.T4CStatement.doOall8(T4CStatement.java:213)
        at oracle.jdbc.driver.T4CStatement.doOall8(T4CStatement.java:37)
        at oracle.jdbc.driver.T4CStatement.executeForRows(T4CStatement.java:887)
        at oracle.jdbc.driver.OracleStatement.doExecuteWithTimeout(OracleStatement.java:1136)
        at oracle.jdbc.driver.OracleStatement.executeInternal(OracleStatement.java:1754)
        at oracle.jdbc.driver.OracleStatement.execute(OracleStatement.java:1709)
        at oracle.jdbc.driver.OracleStatementWrapper.execute(OracleStatementWrapper.java:300)
        at connector.DBScriptRunner.executeScript(DBScriptRunner.java:47)
        at connector.DBScriptRunner.main(DBScriptRunner.java:16)
Caused by: Error : 922, Position : 4, Sql = SET DEFINE OFF;, OriginalSql = SET DEFINE OFF;, Error Msg = ORA-00922: missing or invalid option

Kann mir einer einen Tipp geben, wie ich das lösen kann, bzw. wie ich in meinem Pjava rogramm sqlplus commands ausführen kann?

Danke
 

Thallius

Top Contributor
Also wenn ich das richtig verstehe, dann ist sqlplus eine Administrations Software für Oracle. Also kannst du auch keine sqlplus Dateien auf eine Oracle Datenbank anwenden da du es dir Kommandos gar nicht kennt
 

mihe7

Top Contributor
@Thallius liegt vollkommen richtig. Eine für SQL*Plus geschriebene .sql-Datei ist eine SQL*Plus-spezifische Textdatei, die (auch ausschließlich) Oracle SQL enthalten kann. Du könntest natürlich sqlplus von Java aus aufrufen (@Pfad\zur\datei.sql), dafür müsste es aber schon einen guten Grund geben. Oft ist man besser dran, den Spaß von SQL*Plus nach Java zu migrieren.
 

mihe7

Top Contributor
Damit meine ich, die Funktionalität des Skripts in Java nachzubauen. Beispielsweise lassen sich Substitution von Variablen, bind variables usw. - je nach Skript - mit vertretbarem Aufwand wesentlich schöner in Java (PreparedStatement) umsetzen.
 

guguli

Bekanntes Mitglied
Ich hab geschafft, dass die User erstellt werden, jedoch bei einer Zeile fliegt eine Exception. Das ist die Ausgabe und exception, die Fliegt:

Code:
Line: CREATE USER assentis27 IDENTIFIED BY assentis
Line: GRANT CONNECT TO assentis27
Line: GRANT CREATE TABLE TO assentis27
Line: GRANT CREATE SEQUENCE TO assentis27
Line: GRANT CREATE ANY INDEX, SELECT ANY TABLE TO assentis27
Line: GRANT CREATE TRIGGER TO assentis27
Line: GRANT CREATE PROCEDURE TO assentis27
Line: GRANT UNLIMITED TABLESPACE TO assentis27
Line: GRANT EXECUTE ON SYS.DBMS_AQADM to assentis27
Line: GRANT EXECUTE ON SYS.DBMS_AQ to assentis27
Line: ALTER USER assentis27 QUOTA UNLIMITED ON SYSTEM
Line: GRANT SELECT ON SYS.DBA_RECYCLEBIN TO assentis27
*** Error : java.sql.SQLSyntaxErrorException: ORA-01031: insufficient privileges

Weisst einer woran das liegen kann?
 

guguli

Bekanntes Mitglied
Das ist leider nicht die Lösung: denn wenn ich die connection so aufbaue:

Code:
"jdbc:oracle:thin:@//hostname:1521/romdb", "user as sysdba","pwd"

dann bekomme ich folgende meldung:
java.sql.SQLException: ORA-01017: invalid username/password; logon denied
 

guguli

Bekanntes Mitglied
Also, auf meine Lokalen Centos VM bin ich als root angemeldet. Dadrin führe ich eine .sh datei aus, In dieser Datei wird .sql files erstellt, dann führe ich eine runnable .jar file aus, in der die DB connection, wie oben angegeben, erstellt wird und .sql files werden dann zeilenweise gelesen und ausgeführt. Alle zeilen werden ausgeführt bis auf "GRANT SELECT ON SYS.DBA_RECYCLEBIN TO assentis27".

Also ich würde sagen, ja ich bin Administrator. Ich weiss allerdings nicht ob der User, den ich bei der Conection Aufbau angegeben habe, Admin ist oder nicht :(.
Aber wenn das nicht so wäre, dann hatte ich auch nicht folgende Zeilen ausführen können oder?:
GRANT EXECUTE ON SYS.DBMS_AQADM to assentis27
GRANT EXECUTE ON SYS.DBMS_AQ to assentis27
 

Thallius

Top Contributor
Nein die Datenban liegt extern auf einer anderen Maschine.
ok dann muss ich schauen, ob der user Adminrechte hat oder nicht.

In der Regel geben die Admins einer DB keine Rechte an andere User die User zu ändern. Das sollte immer zentral nur über die Admins laufen und auf keinen Fall sollte eine Applikation die Userrechte einer DB ändern können.
 

mihe7

Top Contributor
Ich weiss allerdings nicht ob der User, den ich bei der Conection Aufbau angegeben habe, Admin ist oder nicht
Das ist der entscheidende Punkt.

Aber wenn das nicht so wäre, dann hatte ich auch nicht folgende Zeilen ausführen können oder?:
Wenn dem User z. B. die EXECUTE-Berechtigung "WITH GRANT OPTION" erteilt wurde, kann er die Berechtigung für dieses Objekt an andere erteilen.
 

guguli

Bekanntes Mitglied
ok, ich habe jetzt einen user mit admin Rechte, so mit dem kann ich nun alles ausführen.

jetzt muss ich aber so eine statement ausführen:

Code:
begin
               DBMS_AQADM.GRANT_SYSTEM_PRIVILEGE (privilege => 'ENQUEUE_ANY', grantee => 'omcore27', admin_option => FALSE);
               DBMS_AQADM.GRANT_SYSTEM_PRIVILEGE (privilege => 'DEQUEUE_ANY', grantee => 'omcore27', admin_option => FALSE);
               DBMS_AQADM.GRANT_SYSTEM_PRIVILEGE (privilege => 'MANAGE_ANY', grantee => 'omcore27', admin_option => FALSE);
           end;/

kann einer mir sagen wie ich das zeilenweise lesen kann und als eine Statemnt ausführen kann?
Also ich lese die .sql file zeilenweise und dann führe die zeilen jeweils aus:

sowas ähnliches will ich haben.
Code:
while ((line = reader.readLine()) != null) {
               if (line.startWith("begin")){
                     //nächste Zeile bekommen bis "End;/" vorkommt
               }
}
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
X Betriebssytem interne Consolen Commands über Java starten Java Basics - Anfänger-Themen 2
Kasoki Eigene Funktionen / Commands Java Basics - Anfänger-Themen 14
M Actions, Menues und Commands in Eclipse Java Basics - Anfänger-Themen 7
H .java Dateien in Eclipse einbinden und ausführen Java Basics - Anfänger-Themen 1
onlyxlia Schlüsselworte Was meint man mit "einen Typ" in Java erstellen? Java Basics - Anfänger-Themen 2
O Java Kara geschweifte Klammern Java Basics - Anfänger-Themen 2
richis-fragen Mausrad logitech kann links und rechts klick wie in java abragen. Java Basics - Anfänger-Themen 15
XWing Java Klssenproblem Java Basics - Anfänger-Themen 4
R Umgebungsvariable java -cp gibt immer Java-Hilfe... Java Basics - Anfänger-Themen 3
farbenlos Csv Datei in Java einlesen Java Basics - Anfänger-Themen 18
F TableModelListener: java.lang.ArrayIndexOutOfBoundsException: 132 Java Basics - Anfänger-Themen 3
G Java 8 - Support-Ende Java Basics - Anfänger-Themen 7
T Java Weihnachtsbaum + Rahmen Java Basics - Anfänger-Themen 1
N Will mit Java anfangen Java Basics - Anfänger-Themen 13
Ü Java Array - Buchstaben als Zahlen ausgeben Java Basics - Anfänger-Themen 22
M Java Iterator Verständnisfrage Java Basics - Anfänger-Themen 6
M Java Mail Programm Java Basics - Anfänger-Themen 4
Sniper1000 Java 391 für Windows Java Basics - Anfänger-Themen 37
J Java long- in int-Variable umwandeln Java Basics - Anfänger-Themen 6
JaZuDemNo Java im Studium Java Basics - Anfänger-Themen 7
E Java Programm zur anzeige, ob Winter- oder Sommerzeit herrscht Java Basics - Anfänger-Themen 62
I QR code in Java selber generieren Java Basics - Anfänger-Themen 5
V Java-Ausnahmebehandlung: Behandlung geprüfter Ausnahmen Java Basics - Anfänger-Themen 1
krgewb Java Streams Java Basics - Anfänger-Themen 10
A Überwältigt von der komplexen Java Welt Java Basics - Anfänger-Themen 29
O Mehrfachvererbung auf Spezifikations- und Implementierungsebene in Java. Interfaces Java Basics - Anfänger-Themen 19
John_Sace Homogene Realisierung von Generics in Java ? Java Basics - Anfänger-Themen 19
P Meldung aus Java-Klasse in Thread an aufrufende Klasse Java Basics - Anfänger-Themen 1
R mit Java API arbeiten Java Basics - Anfänger-Themen 9
P JDK installieren Probleme bei der Java-Installation Java Basics - Anfänger-Themen 8
S Java: Wie sortiere ich eine ArrayList benutzerdefinierter Objekte nach einem bestimmten Attribut? Java Basics - Anfänger-Themen 2
Timo12345 JNLP File mit Java öffnen Java Basics - Anfänger-Themen 2
S Video Editierung mit Java.._ Java Basics - Anfänger-Themen 2
F Einstelungen in Java - CursorBlinkRate Java Basics - Anfänger-Themen 10
A PHP $_POST["name"] in Java Java Basics - Anfänger-Themen 3
vivansai21 Is there a oneliner to create a SortedSet filled with one or multiple elements in Java? Java Basics - Anfänger-Themen 9
Athro-Hiro Weißes Bild in Java erstellen Java Basics - Anfänger-Themen 3
Arjunreddy Can someone please tell me how to use a debugger in BlueJ(a Java environment) Java Basics - Anfänger-Themen 1
M Java assoziationen (UML) Java Basics - Anfänger-Themen 8
H Excel-Tabellen mit Java erstellen Java Basics - Anfänger-Themen 4
Simon16 Java ArrayListe von einer Klasse sortieren Java Basics - Anfänger-Themen 2
P Wie kann ich in meinem Java Programm etwas dauerhaft speichern? Java Basics - Anfänger-Themen 5
H Nutzt Eclipse alle CPU-Threads beim Ausführen von Java-Programmen? Java Basics - Anfänger-Themen 4
xXGrowGuruXx Java einstieg, leichte sache 0 verstanden Java Basics - Anfänger-Themen 7
A java.sql.SQLException: Data type mismatch. Java Basics - Anfänger-Themen 1
H Java-Programm zur Ausgabe von Zuständen Java Basics - Anfänger-Themen 80
N Java Spiel Figur auf dem Hintergrundbild bewegen. Java Basics - Anfänger-Themen 11
G Kann Java-Programm nicht als jar aufrufen, auch als EXE nicht Java Basics - Anfänger-Themen 19
N Java Taschenrechner hat Jemand vlt einen Tipp dafür wie ich jetzt die buttons verbinden kann und das Ergebnis auf dem textfield anzeigen lassen kann Java Basics - Anfänger-Themen 13
A Lerngruppe Java Java Basics - Anfänger-Themen 2
G Help me in the Java Program Java Basics - Anfänger-Themen 2
L Java- Vererbung Java Basics - Anfänger-Themen 4
LimDul Suche Java Stream Tutorial Java Basics - Anfänger-Themen 2
_so_far_away_ Ich möchte Java lernen Java Basics - Anfänger-Themen 11
benny1993 Java Programm erstellen für ein Fußball-Turnier Java Basics - Anfänger-Themen 3
M Datentypen While-Schleife eine Java Methode erstellen Java Basics - Anfänger-Themen 3
V Bild per Java Script austauschen Java Basics - Anfänger-Themen 7
MoxMorris this Keyword in Java Java Basics - Anfänger-Themen 14
D Wie kann man in Java nach Arrays auf Duplikate prüfen Java Basics - Anfänger-Themen 12
wolei JAVA Zeitdifferenz feststellen. Java Basics - Anfänger-Themen 4
DiyarcanZeren Rekursion in Java Java Basics - Anfänger-Themen 5
wolei Java generic interface in a generic class Java Basics - Anfänger-Themen 6
monsterherz Ablauf der Erstellung eines Java Programmes Java Basics - Anfänger-Themen 17
monsterherz Circle.java:5: error: <identifier> expected Java Basics - Anfänger-Themen 2
julian-fr Wie kann ich am besten Java lernen? Java Basics - Anfänger-Themen 17
A Java-Properties und -RessourceBundles Java Basics - Anfänger-Themen 5
lrnz22 Java-Basics-Aufgabe Java Basics - Anfänger-Themen 8
R Java kann nicht installiert werden Java Basics - Anfänger-Themen 8
marcelnedza Finde meinen Fehler in einer Methode nicht, Java Karol Java Basics - Anfänger-Themen 15
G In ein java Dokument Ton einbinden Java Basics - Anfänger-Themen 1
C was heisst es wenn java ']' erwartet ? Java Basics - Anfänger-Themen 2
KeinJavaFreak Erste Schritte Programm "Java(TM) Platform SE binary " nicht vorhanden Java Basics - Anfänger-Themen 1
KeinJavaFreak Erste Schritte Java "Executable Jar File" nicht vorhanden Java Basics - Anfänger-Themen 1
melisax Java 2D-Array Tabelle Java Basics - Anfänger-Themen 4
melisax Java Array Wert an bestimmtem Index angeben Java Basics - Anfänger-Themen 14
J Java Testklasse Java Basics - Anfänger-Themen 5
P Java Selenium . Parameterized.Parameters erzeugt eine Fehlermeldung Java Basics - Anfänger-Themen 14
W Java-Code mit Array Java Basics - Anfänger-Themen 14
W Java-Code Java Basics - Anfänger-Themen 2
P BeforeEach AfterEach werden nicht ausgeführt. Java / Selenium Java Basics - Anfänger-Themen 4
A Wie führe ich eine Batch-Datei von meiner Java-Anwendung aus? Java Basics - Anfänger-Themen 18
W Java code- TicTac toe Java Basics - Anfänger-Themen 51
Ostkreuz Java Docs Java Basics - Anfänger-Themen 9
R Java boolean Unterschied " == " und " = " Java Basics - Anfänger-Themen 3
D Java Programm mit Batch-Datei starten Java Basics - Anfänger-Themen 32
W Java-code Java Basics - Anfänger-Themen 8
W Java-code Java Basics - Anfänger-Themen 9
W Java-Code erklären Java Basics - Anfänger-Themen 6
A Java Kurs / Tutorial Java Basics - Anfänger-Themen 6
K Java Lotto Spiel; ich komme nicht weiter Java Basics - Anfänger-Themen 15
R Operatoren Rechenoperation in Java verwenden für Calculator Java Basics - Anfänger-Themen 2
P Java 2n Potenzieren Java Basics - Anfänger-Themen 1
J Java Hamster Java Basics - Anfänger-Themen 4
D Wie sehe ich ein Java-Programm? Java Basics - Anfänger-Themen 27
V Die Funktion des neuen Schlüsselworts in Java Java Basics - Anfänger-Themen 1
W Junit-Test (Java) Java Basics - Anfänger-Themen 4
W Testfälle bei Java ( Junit-Test) Java Basics - Anfänger-Themen 3
laxla123 If-else Java Java Basics - Anfänger-Themen 4
RashAGhul Java Verwaltungstool Erstellen mit kaum Wissen Java Basics - Anfänger-Themen 9
S Substring in java Java Basics - Anfänger-Themen 3

Ähnliche Java Themen

Neue Themen


Oben