Oracle数据库对于大对象二进制文件的存储及下载 | 您所在的位置:网站首页 › 重庆邮电大学研究生宿舍安排表 › Oracle数据库对于大对象二进制文件的存储及下载 |
什么是大对象二进制文件类型? Oracle数据库对于大对象二进制文件的存储可以使用Blob和Clob两种类型字段。 也就是说我们可以向数据库当中直接存储以二进制形式的图片、声音、视频等,此时就需要用到Blob类型。Blob与Clob的不同: 如果大对象文件为二进制文件,应该选择blob类型,如果大对象类型为文本文件,应选择clob类型。 下面为大家演示如何使用Oracle的SqlDeveloper将图片以二进制形式存储: (1)首先要在所使用的文件表里新建一个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 实验室设备网 版权所有 |