我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Oracle中bfile类型的用法

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Oracle中bfile类型的用法

本篇内容介绍了“Oracle中bfile类型的用法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

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可能会产生不同的结果。 

“Oracle中bfile类型的用法”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Oracle中bfile类型的用法

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

oracle number类型用法

Oracle 中的 NUMBER 类型是一种用于存储数值的数据类型。以下是 NUMBER 类型的用法:1. 声明 NUMBER 类型变量:```DECLAREnum_val NUMBER;BEGINnum_val := 10;DBMS_OU
2023-09-23

oracle中integer类型赋值的方法是什么

在Oracle中,可以使用常规的赋值语法将整数值赋给INTEGER数据类型的变量。例如:DECLAREnum INTEGER;BEGINnum := 10;END;在上面的示例中,我们声明了一个INTEGER类型的变量num,并将整数
oracle中integer类型赋值的方法是什么
2024-04-09

复合类型变量在Oracle中的使用

在Oracle中,复合类型变量通常是通过使用记录类型或对象类型来创建的。记录类型是一种包含多个字段的结构,类似于结构体或元组,而对象类型则是一种用户定义的数据类型,可以包含多个属性和方法。以下是在Oracle中使用复合类型变量的一些示例:
复合类型变量在Oracle中的使用
2024-08-24

java中引用类型的用法总结

一、class作为成员变量在定义一个类Role(游戏角色)时,代码如下:使用 int 类型表示角色id和生命值,使用String类型表示姓名。此时,String 本身就是引用类型,由于使用的方式类似常量,所以往往忽略了它是引用类型的存在。如果我们继续丰富这个类
java中引用类型的用法总结
2016-05-29

Oracle 中常见的日志类型及配置方法

Oracle 中常见的日志类型及配置方法Oracle 数据库是业界领先的关系型数据库管理系统之一,它提供了丰富的日志类型来记录数据库的操作和性能信息。在实际的数据库管理工作中,了解并配置好这些日志类型对于监控和优化数据库非常重要。本文将介
Oracle 中常见的日志类型及配置方法
2024-03-09

Pandas数据类型中category的用法

本篇内容主要讲解“Pandas数据类型中category的用法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Pandas数据类型中category的用法”吧!创建category使用Series
2023-06-20

Oracle中Blob和Clob数据类型的区别及用法介绍

Oracle数据库中的Blob和Clob数据类型在存储大型数据对象时起着重要作用。Blob用于存储二进制数据,例如图片、音频或视频文件,而Clob用于文本数据,例如长文本、HTML页面等。本文将详细介绍Blob和Clob数据类型的区别及使用
Oracle中Blob和Clob数据类型的区别及用法介绍
2024-03-08

Java中引用类型class的用法总结

这篇文章主要为大家详细介绍了Java中引用类型class的用法的相关资料,文中的示例代码讲解详细,对我们学习Java有一定帮助,感兴趣的可以了解一下
2022-11-13

oracle中rowid是什么类型

rowid 是 oracle 中一种唯一标识物理数据库中一行的专有数据类型,因为它唯一且持久,且可以在行被移动或更新时保持不变。优点包括检索速度快,可以使用 rowid 伪列获取,并用于快速查找行、比较行和移动行。Oracle 中的 ROW
oracle中rowid是什么类型
2024-05-08

oracle number类型怎么使用

Oracle数据库中的NUMBER类型是用于存储数值的数据类型,可以表示正数、负数和零。下面是如何使用NUMBER类型的一些常见操作:1. 创建表时指定列的数据类型为NUMBER:```sqlCREATE TABLE my_table (i
2023-08-29

编程热搜

目录