Oracle中bfile类型的用法
admin
2023-05-08 07:22:01
0

bfile类型是一种lob类型,bfile类型只是操作系统上一个文件的指针,用于为操作系统文件提供只读访问。在数据库之外进行维护,不是数据库的一部分。

使用bfile时,需要使用一个Oracle的directory对象,directory对象只是将一个操作系统目录映射至数据库中的一个"串"或一个名称。

创建表bfile_test,os_file字段类型为bfile

SQL> create table bfile_test (id int primary key,os_file bfile) ;

创建用于存放文件的目录

SQL> create or replace directory my_dir as '/home/oracle/photo';

向表中插入内容

SQL> insert into bfile_test values(1,bfilename('MY_DIR','1.jpg')) ;

SQL> commit ;

可以看到指定文件的大小

SQL> select dbms_lob.getlength(os_file) from bfile_test ;

注意在插入的时候,my_dir一定要大写,否则会出现错误。(插入时正常,查询的时候会出错)

SQL> insert into bfile_test values(2,bfilename('my_dir','1.jpg')) 

SQL> commit ;

SQL> select dbms_lob.getlength(os_file) from bfile_test ;

ERROR:

ORA-22285: non-existent directory or file for GETLENGTH operation

ORA-06512: at "SYS.DBMS_LOB", line 850

SQL> select * from bfile_test ;

在plsql developer中查看时,第一次插入的是正常的,第二次插入查看显示Value Error

bfile在磁盘上占用的空间不定,取决于directory对象名和文件名的长度,一般来说,bfile会占用大约20字节的开销。

和其他的lob数据不同,bfile数据不是"读一致"的,由于bfile在数据库之外进行管理,对bfile接触引用的时候,不论文件上发生了什么,都会反映到得到的结果中,所以,反复读同一个bfile可能会产生不同的结果。 

相关内容

热门资讯

今年以来,越来越多美国交流团来... 4月,数十名美国犹他州青少年来豫参加2026年YES项目交流活动。图为美国青少年在郑州体验书法项目。...
“打工机器人”亮相郑州街头 机器人服务员“小盖”在郑州街边的一零售店工作。 王磊 摄机器人当服务员,在街头卖咖啡——这不是科幻电...
打响“河南服务”品牌丨盾构机有... 【开栏的话】为深入贯彻落实全省服务业大会精神,本报即日起开设“打响‘河南服务&rsquo...
一季度我国数字产业收入9.5万... 【大河财立方消息】5月14日,工信部发布的数据显示,一季度,我国数字产业实现良好开局,行业利润大幅改...
一体推进整治形式主义为基层减负... 形式主义实质是主观主义、功利主义,根源是政绩观错位、责任心缺失。当前,各地以深化“六个纠治”为抓手,...
5月上旬汽油柴油价格环比继续下... 【大河财立方消息】 5月14日,国家统计局发布2026年5月上旬流通领域重要生产资料市场价格变动情况...
河南信阳凌晨通报:常某朋(男,... 2026年5月13日21时43分许,我市浉河区发生一起道路交通事故。经查,常某朋(男,40岁)驾驶私...
马化腾回应腾讯AI是否落后;曝... “IT早报”时间,大家好,现在是 2026 年 5 月 14 日星期四,今天的重要科技资讯有: 1、...
马斯克宣布xAI将终止独立运营... 5月7日凌晨,马斯克在X上发布消息称旗下人工智能公司xAI将终止独立运营。马斯克表示,xAI将整体并...
韩国大学生的梦中情岗:海力士保... 文/凯斯 王动 编辑/章鱼在当下的韩国,最具性张力的东西是什么?不是水光肌,不是牛舔头,而是一件海力...