如何使用Vert.x將Blob插入Oracle數據庫11g? [英] how to insert Blob into oracle database 11g using Vert.x?

查看:0
本文介紹了如何使用Vert.x將Blob插入Oracle數據庫11g?的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!

問題描述

我正在嘗試使用vert.x將BLOB插入Oracle數據庫,我得到了上載文件

     for (FileUpload f : routingContext.fileUploads()){
         System.out.println("file name " + f.fileName());
         System.out.println("size name " + f.size());
         System.out.println("Uploaded File " + f.uploadedFileName());
     }

我使用以下命令將FileUpload轉換為字節數組:

 Buffer fileUploaded = routingContext.vertx().fileSystem().readFileBlocking(f.uploadedFileName());

 byte[] fileUploadedBytes = fileUploaded.getBytes();
現在我想將其直接插入Oracle數據庫,我已經嘗試使用updateWithParams,但我不知道如何將Blob添加到查詢參數中。 感謝您的幫助

推薦答案

這是我的實現來解決我的問題,現在我可以將文件BLOB插入到ORACLE數據庫中,我希望這能在未來對某人有所幫助。

 ByteArrayInputStream finalBis = bis;
    byte[] finalFileUploadedBytes = fileUploadedBytes;
    DB.getConnection(connection -> {
        if (connection.succeeded()) {
            CallableStatement stmt = null;
            try {
                stmt = connection.result().getConnection().prepareCall(SQL.INSERT_DOCS_QUERY);
                stmt.setBinaryStream(1, finalBis, finalFileUploadedBytes.length);
                stmt.setString(2,desiDoc);
                stmt.setString(3,sourDoc);
                logger.debug(stmt);
                stmt.execute();
                finalBis.close();
            } catch (SQLException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
        } else {
            System.out.println("nooot  ok");
        }
    });

這篇關于如何使用Vert.x將Blob插入Oracle數據庫11g?的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持IT屋!

查看全文
登錄 關閉
掃碼關注1秒登錄
發送“驗證碼”獲取 | 15天全站免登陸
全免费A级毛片免费看无码播放