Oracle数据库对于大对象二进制文件的存储及下载

  • 什么是大对象二进制文件类型?

    Oracle数据库对于大对象二进制文件的存储可以使用Blob和Clob两种类型字段。
    也就是说我们可以向数据库当中直接存储以二进制形式的图片、声音、视频等,此时就需要用到Blob类型。
    

    Blob与Clob的不同:
    如果大对象文件为二进制文件,应该选择blob类型,如果大对象类型为文本文件,应选择clob类型。


下面为大家演示如何使用Oracle的SqlDeveloper将图片以二进制形式存储:
(1)首先要在所使用的文件表里新建一个Blob类型的字段用于存储。

这里写图片描述
(2)对Blob类型的字段进行编辑可对其直接存储图片等类型的文件。点击加载即可上传所需要存储的文件。
这里写图片描述

(3)通过编辑页面也可从数据库当中将文件下载到指定位置。


项目需求:
实现从数据库中下载大对象二进制文件并将其下载到磁盘指定位置。

在项目中我使用的是Struts2,因此action当中的代码如下:

  String filename = "test";       
          FileSave fileSave  = uploadService.downLoadFile(filename);//以传入文件名查询FileSave下所有的属性
            BufferedOutputStream bos = null;  
            FileOutputStream fos = null;  
            File file = null;  
            try {  
                File dir = new File("C:\\Users\\Administrator\\Desktop");  
                if(!dir.exists()&&dir.isDirectory()){       //判断文件目录是否存在  
                    dir.mkdirs();  
                }
                file = new File("C:\\Users\\Administrator\\Desktop"+"\\"+fileSave.getFilename()+"."+fileSave.getFiletype());  
                fos = new FileOutputStream(file);  
                bos = new BufferedOutputStream(fos);  
                bos.write(fileSave.getFileblob());  

            } catch (Exception e) {  
                e.printStackTrace();  
            } finally {  
                if (bos != null) {  
                    try {  
                        bos.close();  
                    } catch (IOException e1) {  
                        e1.printStackTrace();  
                    }  
                }  
                if (fos != null) {  
                    try {  
                        fos.close();  
                    } catch (IOException e1) {  
                        e1.printStackTrace();  
                    }  
                }  
            }      

这里可以解释一下,首先实体类中的存储二进制文件的属性的类型为byte[]数组(即:private byte[] fileblob),然后通过文件名这个条件将文件类下所有的属性查询出来,之后将文件进行byte[] 数组间的转换,便能将其下载到指定文件位置。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值