Not only developing

Linux,Oracle,Java and much more…..

Select * from C:\ ??? Ecco come farlo in Oracle

Pubblicato da teox78 su Novembre 27, 2007

In questi giorni ho iniziato a sviluppare un nuovo processo che ha come database Oracle.

Prima di caricare alcuni file csv,l’utente deve avere la possibilità di vedere il contenuto di alcune directory non sempre visibili dalla macchina dell’utente quindi ho deciso che la soluzione ottimale fosse avere questo elenco all’interno di Oracle, ad esempio tramite una vista che interrogasse direttamente il filesystem. Ecco come fare tutto ciò :

  • CREATE OR REPLACE TYPE StringArray AS TABLE OF VARCHAR2(512);
  • CREATE OR REPLACE AND RESOLVE JAVA SOURCE NAMED "FileHandler" AS
    import java.io.*;
    import java.sql.*;
    import oracle.sql.*;
    import oracle.jdbc.driver.*;
    public class FileHandler {
    public static oracle.sql.ARRAY list(String dirName) throws SQLException {
    Connection conn = null;
    int ret_code;
    String[] files = null;
    File file = new File(dirName);
    if (file.exists()) {
    if (file.isDirectory()) {
    if (file.canRead()) {
    files = file.list();
    }
    }
    }
    try {
    conn = new OracleDriver().defaultConnection();
    ArrayDescriptor x_ad = ArrayDescriptor.createDescriptor(
    "STRINGARRAY", conn);
    ARRAY x_array = new ARRAY(x_ad, conn, files);
    return x_array;
    } catch (SQLException e) {
    ret_code = e.getErrorCode();
    System.err.println(ret_code + e.getMessage());
    conn.close();
    return null;
    } finally {
    closeConnection(conn);
    }
    }private static void closeConnection(Connection connection) {
    if (connection == null) {
    return;
    } else {
    try {
    connection.close();
    } catch (Exception e) {
    System.out.println(e.getMessage());
    }
    connection = null;
    }}
    };
    /
  • CREATE OR REPLACE FUNCTION list (p_path IN VARCHAR2) RETURN StringArray AS LANGUAGE JAVA NAME 'FileHandler.list (java.lang.String) return oracle.sql.ARRAY';
  • EXEC DBMS_JAVA.grant_permission('SCHEMA-NAME', 'java.io.FilePermission', '<<ALL FILES>>', 'read ,write, execute, delete');
    EXEC DBMS_JAVA.grant_permission('SCHEMA-NAME', 'SYS:java.lang.RuntimePermission', 'writeFileDescriptor', '');
    EXEC DBMS_JAVA.grant_permission('SCHEMA-NAME', 'SYS:java.lang.RuntimePermission', 'readFileDescriptor', '');
    GRANT JAVAUSERPRIV TO SCHEMA-NAME;

A questo punto sarà sufficiente fare una query come quella seguente per ottenere tutti i file e directory presenti sul disco C della macchina sulla quale c’è il database.

SELECT * FROM TABLE(LIST('C:\'))

Naturalmente questo è solo un esempio che mostra la strada che ,secondo me, è meglio seguire; si potrebbero creare strutture più complesse che oltre al nome del file restituiscano la dimensione o la data dello stesso.

Lascia una Risposta

XHTML: Puoi usare questi tag: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <pre> <del datetime=""> <em> <i> <q cite=""> <strike> <strong>