什么是大对象二进制文件类型?
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[] 数组间的转换,便能将其下载到指定文件位置。