Oracle中的文件保存方式(oracle保存文件)

Oracle是一种多用途的关系数据库管理系统,广泛应用于各种行业的数据库软件,可以用来储存用户所需的文档和文件,Oracle中的文件保存方式主要有三种:BLOB、BFILE和SecureFiles,简要介绍如下:

BLOB是Binary Large Object的缩写,指的就是大型二进制对象。它可以存放任何类型的文件,如txt、word、excel等,可以使用SQL语句或PL/SQL来实现对BLOB字段的操作,例如插入、更新或读取,比如:

-- 将二进制文件放入BLOB字段  
filestream bPhoto;
bFile bf := bFile('/tmp/tom_photo.gif');
bPhoto := bf.getBlob();
insert into employees (photo) values (bPhoto)

BFILE就是外部文件(Externally Stored File),它存放在数据库外部的文件,而不是存放在数据库内部,数据库内只保存BFILE文件的指针,使用BFILE时,我们需要将文件复制到外部目录中,然后设置目录权限,操作BFILE文件可以使用如下语句:

-- 将文件复制到外部目录中

declare
fs bFile;
begin
fs:= bFile('/tmp/emp.jpg');
for dbms_lob.fileopen(fs);
end;

SecureFiles也是用于存储文件的字段,它可以减少额外存储空间,在插入文件时,SecureFiles可以首先将文件比较小的内容编制到表中,大小超过32KB的文件将会以外部文件的形式存在,SecureFiles用来创建BLOB字段如下:

create table mytable (
myid varchar2 (20),
myfile SYS.SecureFile_Dflt
);

Oracle中的文件保存方式主要有BLOB、BFILE和SecureFiles这三种,无论使用哪种方式,都需要经过相应的SQL语句或PL/SQL来实现。使用之前还要对所存文件的类型和大小有一定的认识,以便选择最合适的方式。


数据运维技术 » Oracle中的文件保存方式(oracle保存文件)