问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

如何将二进制文件存入Oracle数据库中

发布网友 发布时间:2022-04-07 17:43

我来回答

1个回答

热心网友 时间:2022-04-07 19:12

先把文件读取到内存,再以二进制格式保持到数据库中的大字段中(clob或clob)。
写大对象。

Java code

public static void main(String[] args) {
// TODO Auto-generated method stub
Connection conn = null;
Statement stat = null;
ResultSet rs = null;
OutputStream os = null;
FileInputStream fis = null;
int bs = 0;
try {
Class.forName("oracle.jdbc.driver.OracleDriver");
conn = DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:oraDB","bigfou","---");
conn.setAutoCommit(false);
stat = conn.createStatement();
stat.executeUpdate("insert into t_video(id,video) values(1,empty_blob())");

rs = stat.executeQuery("select video from t_video where id = 1");
rs.next();
oracle.sql.BLOB blo = (oracle.sql.BLOB)rs.getBlob(1);
os = blo.getBinaryOutputStream();
bs = blo.getBufferSize();
fis = new FileInputStream("D:\\Temp\\MPlayer-CVS-20040808-K&K\\mplayer.exe");
byte[] buf = new byte[bs];
int length = 0;

while(true)
{
length = fis.read(buf);
if(length == -1) break;
os.write(buf,0,length);
}

os.close();
os = null;
fis.close();
fis = null;
conn.commit();
conn.setAutoCommit(true);
conn.close();
} catch(Exception ex) {
ex.printStackTrace();
}
}

读大对象

Java code

InputStream is = null;
FileOutputStream fos = null;
byte[] buf = null;
int bs = 0;

try {
Class.forName("oracle.jdbc.driver.OracleDriver");
conn = DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:oraDB","bigfou","-");
conn.setAutoCommit(false);
stat = conn.createStatement();

rs = stat.executeQuery("select video from t_video where id = 1");
rs.next();
oracle.sql.BLOB blo = (oracle.sql.BLOB)rs.getBlob(1);
bs = blo.getBufferSize();
buf = new byte[bs];
int length = 0;
is = blo.getBinaryStream();
fos = new FileOutputStream("d:\\test.exe");

while(true) {
length = is.read(buf);
if(length == -1) break;
fos.write(buf,0,length);
}

fos.close();
fos = null;
is.close();
is = null;
conn.commit();
conn.setAutoCommit(true);
conn.close();
...
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
LOL金币买英雄好还是符文好 LOL25级三千金币买英雄好还是买符文? LOL里金币用来买英雄还是买符文? lol我现在11级攒到了6000+金币,现在是买英雄还是等到20买符文 lol本人有4000金币不知是买符文先还是英雄先好?听说不买符文很吃亏... lol s4符文怎么配 ...我才刚满20级 是现在买符文 还是等到s4赛季开始再买符文 变化大么... 不知道lol金币到了6300现在买符文还是英雄 LOL已经14级了 现有6300金币买不买英雄 还是存着到20买符文 生地功效与作用是什么 photoshop修复工具有哪些 电脑登陆快手直播伴侣的时候提示初始化视频失败,未指定错误,是怎么回事 快手直播伴侣直播游戏,开始直播后显示启动失败,请切换到桌面手动启动怎么回事? ps中的修补工具怎么用?要详细点。 为什么电脑使用xmind ps里的污点修复画笔工具、修复画笔工具、修补工具有什么区别? 快手直播伴侣登录不了怎么办 ps修补工具会多选 xmind怎么在mindmanager 中打开 如何安装xmind-8-linux.zip linux mint怎么安装xmind xmind文件,双击没反应打不开,须先打开xmind软件,然后通过“文件》打开》…”的方式才行,如何解决 Linux版Xmind安装后无法使用 小度在家1c整天插电全天的经过都能录像吗? 昨晚梦见去世外公外婆吃饭 m.sosuo.name 小度在家1C可以一直不拔电源吗?不用的时候待机 小度1c断电后还能继续播放歌曲吗? 梦见己故的外公外婆一起煮饭吃 梦见和死去的,外公,外婆,弟弟一起吃饭,他们看起来不开心!醒来后 小杜不插电就不工作吧? 云南邵通一位父亲房内睡觉女童爬窗不慎坠亡,窗户安防护网是不是很有必要? 笔记本无线鼠标那种品牌好用? 麻烦哪位ps高手将下面图片人物中手里的东西换成一张纸,纸上有手写的三个字“梁庆涛”? 因有自信坚持而成功的例子? 最近晚上睡觉时总是脖子痛的睡不着是怎么回事? 哪位ps高手能帮忙处理下这个图片?感谢~~ 举出一个因自信而成功的名人事例 李逵的绰号? 儿童隐形防护网安全吗 梁庆英文名字简称怎么写 成功来于自信 作文 要有事例的 电饭锅边煮饭边蒸菜煮的饭是夹生的正常吗? 防小孩掉下窗户 安置的东西叫什么 哪个人物自信是成功的基石具体事例200字 怕小孩翻窗户弄什么好?装防护网又怕小孩卡住! 平开窗如何安装防护网呢? 平开窗怎么装防护网 ...安装完成后C盘根目录下的Autodesk文件夹可以删除吧? 3dsmax卸载完成后为什么c盘还有Autodesk文件夹? 比鲁斯和维斯被谁杀的?