本文介紹了如何使用Vert.x將Blob插入Oracle數(shù)據(jù)庫(kù)11g?的處理方法,對(duì)大家解決問(wèn)題具有一定的參考價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧!
問(wèn)題描述
我正在嘗試使用vert.x將BLOB插入Oracle數(shù)據(jù)庫(kù),我得到了上載文件
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轉(zhuǎn)換為字節(jié)數(shù)組:
Buffer fileUploaded = routingContext.vertx().fileSystem().readFileBlocking(f.uploadedFileName());
byte[] fileUploadedBytes = fileUploaded.getBytes();
現(xiàn)在我想將其直接插入Oracle數(shù)據(jù)庫(kù),我已經(jīng)嘗試使用updateWithParams
,但我不知道如何將Blob添加到查詢(xún)參數(shù)中。
感謝您的幫助
推薦答案
這是我的實(shí)現(xiàn)來(lái)解決我的問(wèn)題,現(xiàn)在我可以將文件BLOB插入到ORACLE數(shù)據(jù)庫(kù)中,我希望這能在未來(lái)對(duì)某人有所幫助。
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");
}
});
這篇關(guān)于如何使用Vert.x將Blob插入Oracle數(shù)據(jù)庫(kù)11g?的文章就介紹到這了,希望我們推薦的答案對(duì)大家有所幫助,