Oracle数据库对于大对象二进制文件的存储及下载 您所在的位置:网站首页 重庆邮电大学研究生宿舍安排表 Oracle数据库对于大对象二进制文件的存储及下载

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

2024-02-21 14:20| 来源: 网络整理| 查看: 265

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

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[] 数组间的转换,便能将其下载到指定文件位置。



【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有