У меня есть сценарий SQL под названием setup, который устанавливает некоторые параметры, а затем объявляет пакет PL/SQL под названием salespack
setup.sql:
set verify off
set feedback off
set serveroutput on;
set linesize 200;
@Package/pack.sql
@Package/packbody.sql
У меня есть файл main.java, который пытается запустить вышеупомянутый SQL-скрипт, а затем сделать вызов пакета, но это, похоже, не работает. Как я могу использовать jdbc для вызова SQL-скрипта, объявить PL/SQL-пакет, а затем использовать функцию в пакете. Ошибка, которую я получаю, заключается в том, что callstmt.execute(); является недопустимым оператором SQL.
main.java:
import java.sql.*;
import java.io.*;
class main
{
public static void main (String args [])
throws SQLException, IOException
{
DriverManager.registerDriver(new oracle.jdbc.driver.OracleDriver());
String connect = "jdbc:oracle:thin:@vmaddress:1521:xe";
Connection conn = DriverManager.getConnection (connect, "user", "pass");
//Perform setup
//Load packages, allow output, establish sale database
//Make sure to run the main script from dbSetup to have fresh data
CallableStatement callstmt = conn.prepareCall ("@setup.sql");
callstmt.execute();
callstmt.close();
CallableStatement callstmt2 = conn.prepareCall ("{ ? = call salepack.getspname(?) }");
callstmt2.registerOutParameter (1, Types.VARCHAR);
int id = 23; // the id is hard-coded here for simplicity
callstmt2.setInt(2, id);
callstmt2.execute();
String name = callstmt2.getString(1);
System.out.println ("The salesperson with id of " + id + " is " + name);
callstmt2.close();
conn.close();
}
}
Я думаю, вы можете запустить setup.sql с кодом ниже
private static String script_location = "";
private static String file_extension = ".sql";
private static ProcessBuilder processBuilder =null;
public static void main(String[] args) {
try {
File file = new File("C:/sql_folder");
File [] list_files= file.listFiles(new FileFilter() {
public boolean accept(File f) {
if (f.getName().toLowerCase().endsWith(file_extension))
return true;
return false;
}
});
for (int i = 0; i<list_files.length;i++){
script_location = "@" + list_files[i].getAbsolutePath();//ORACLE
processBuilder = new ProcessBuilder("sqlplus", "UserName/Password@database_name", script_location); //ORACLE
//script_location = "-i" + list_files[i].getAbsolutePath();
// processBuilder = new ProcessBuilder("sqlplus", "-Udeep-Pdumbhead-Spc-de-deep\\sqlexpress-de_com",script_location);
processBuilder.redirectErrorStream(true);
Process process = processBuilder.start();
BufferedReader in = new BufferedReader(new InputStreamReader(process.getInputStream()));
String currentLine = null;
while ((currentLine = in.readLine()) != null) {
System.out.println(" " + currentLine);
}
}
} catch (IOException e) {
e.printStackTrace();
}catch(Exception ex){
ex.printStackTrace();
}
}
и, возможно, ниже ссылки дадут вам другую идею;