DBMS_LOB包的使用

1、  dbms_lob.append(

dest_lob  IN  OUT  NOCOPY  BLOB,

src_lob  IN  BLOB)

dbms_lob.append(

dest_lob  IN  OUT  NOCOPY  CLOB  CHARACTER  SET  ANY_CS,

src_lob   IN  CLOB  CHRACTER  SET  dest_lob%CHARSET);

将源LOB变量的内容添加到目标LOB变量的尾部。

示例:dest_lob  clob;

src_lob  clob;

dbms_lob.append(dest_lob,src_lob);

2、  dbms_lob.close(lob_loc  IN  OUT  NOCOPY  BLOB/CLOB/BFILE)

关闭已经打开的LOB。

3、  dbms_lob.compare(

lob_1  IN  BLOB/CLOB/BFILE,

lob_2  IN  BLOB/CLOB/BFILE,

amount  IN  INTEGER:=4294967295,--要比较的字符数(CLOB),字节数(BLOB)

offset_1  IN  INTEGER:=1,--lob_1的起始位置

offset_2  IN  INTEGER:=1--lob_2 的起始位置)

比较两个LOB的内容。

4、 dbms_lob.copy(

dest_lob  IN  OUT  NOCOPY  BLOB/CLOB/NCLOB,

src_lob  IN  BLOB/CLOB/NCOB,

amount  IN  INTEGER,

dest_offset  IN  INTEGER:=1,

src_offset  IN  INTEGER:=1)

从src_lob中,以src_offset为起始位置,截取amount个字符/字节,放到dest_lob的dest_offset位置。

5、 dbms_lob.createtemporary(

lob_loc  IN  OUT  NOCOPY  BLOB/DLOB/NCLOB,

cache  IN  BOOLEAN,

dur  IN  PLS_INTEGER:=10)

在用户的临时表空间中,建立临时LOB。

lob_loc:指定LOB定位符。

Cache:是否将LOB读取到缓冲区。

Dur:指定何时清除临时LOB(10:会话结束时。12:调用结束时)。

6、 dbms_lob.erase(

lob_loc  IN  OUT  NOCOPY  BLOB/CLOB/NCLOB,

amount  IN  OUT  NOCOPY  INTEGER,--字符/字节数

  • offset  IN  INTEGER:=1—起始位置

)

删除LOB变量的内容。

7、 dbms_lob.fileclose(file_loc  IN  OUT  NOCOPY  BFILE)

关闭打开的BFILE定位符所指向的OS文件

8、 dbms_lob.filecloseall关闭当前会话已经打开的所有BFILE文件。

9、 dbms_lob.fileexists(file_loc  IN  BFILE) RETURN  INTEGER

确定file_loc对应的OS文件是否存在,1:存在。0:不存在。

10、dbms_lob.filegetname(

file_loc  IN  BFILE,

dir_alias  OUT  varchar2,

filename  OUT  varchar2)

获取BFILE定位符所对应的目录别名和文件名。

11、dbms_lob.fileisopen(file_loc  IN  BFILE)  RETURN  INTEGER

确定BFILE对应的OS文件是否打开。

12、dbms_lob.freetemporary(lob_lob  IN  OUT  NOCOPY  BLOB/CLOB/NCLOB)

释放在默认临时表空间中的临时LOB。

13、dbms_lob.fileopen(file_loc  IN  OUT  NOCOPY  BFILE,

Open_mode  IN  BINARY_INTEGER:file_readonly)

打开文件。

14、dbms_lob.getchunksize(lob_loc  IN  BLOB/CLOB/NCLOB)  RETURN  INTEGER

当建立包含CLOB/BLOB列的表时,通过指定CHUNK参数可以指定操纵LOB需要分配的字节数(数据库尺寸的整数倍)默认为数据块的尺寸。

15、dbms_lob.getlength(lob_loc  IN  BLOB/CLOB/BFILE/NCLOB) RETURN  INTEGER

获取长度。

16、dbms_lob.instr(

Lob_loc  IN  BLOB/CLOB/NCLOB/BFILE,

Pattern  IN  RAW/VARCHAR2,

Offset  IN  INTERGER:=1,

Nth   IN  INTEGER:=1)  RETURN  INTEGER;

返回特定样式数据从LOB某偏移位置开始出现N次的具体位置。

17、dbms_lob.idopen(lob_loc  IN  BLOB/CLOB/BFILE)  RETURN  INT

确定LOB是否打开,打开:1,未打开:0。

18、dbms_lob.istemporary(lob_loc  IN  BLOB/CLOB/NCLOB)  RETURN  INTEGER

确定定位符是否为临时LOB。

19、dbms_lob.loadfromfile(

dest_lob  IN  OUT  NOCOPY  BLOB/CLOB,

src_file  IN  FILE,

amount  IN  INTEGER,

dest_offset  IN  INTEGER:=1,

src_offset  IN  INTEGER:=1)

将BFILE的部分或全部内容复制到目标LOB变量。

20、dbms_lob.loadblobfromfile(

dest_lob  IN  OUT  NOCOPY  BLOB,

src_bfile  IN  BFILE,

amount  IN  INTEGER,

dest_offset  IN  OUT  INTEGER,

src_offset  IN  OUT  INTEGER)

将BFILE数据装载到BLOB中,并且在装载后取得最新的偏移位置。

21、dbms_lob.open(

lob_loc  IN  OUT  NOCOPY  BLOB/CLOB/BFILE,

open_mode  IN  BINARY_INTEGER)

打开LOB,open_mode(只读:dbms_lob.lob_readonly,读写:dbms_lob.lob_readwrite).

22、dbms_lob.read(

lob_loc  IN  BLOB/CLOB/BFILE,

amount  IN  OUT  NOCOPY  BINARY_INTEGER),--IN:要读取的字符数,

OUT:实际读取的字符数。

Offset  IN  INTEGER,

Buffer  OUT  RAW/VARCHAR2—存储数据的变量

)

将LOB数据读取到缓存区中(变量中)。

23、dbms_lob.substr(

Lob_loc  IN  BLOB/CLOB/BFILE,

Amount  IN  INTEGER:=32762,

Offset  IN  INTEGER:=1) RETURN  RAW/VARCHAR2

与字符处理函数SUBSTR()使用方法一样。

24、dbms_lob.trim(

Lob_loc  IN  OUT  NOCOPY  BLOB/CLOB/NCLOB,

Newlen  IN  INTEGER)

截断LOB到指定长度。

25、dbms_lob.write(

Lob_loc  IN  OUT  NOCOPY  BLOB/CLOB,

Amount  IN  BINARY_INTEGER,

Offset  IN  INTEGER,

Buffer  IN  RAW/VARCHAR2)

将缓冲区数据写入到LOB中的特定位置。

26、dbms_lob.writeappend(

Lob_loc  IN  OUT  NOCOPY  BLOB/CLOB/NCLOB,

Amount  IN  BINARY_INTEGER,

Buffer  IN  RAW/VARCHAR2)

将缓冲区数据写到LOB尾部。

DBMS_LOB包的使用的更多相关文章

  1. Oracle中DBMS_LOB包使用小结

    本文主要介绍oracle数据库中dbms_lob包的使用以及使用dbms_lob包来维护lob数据库类型的基本方法.随着社会的发展,在现代信息系统的开发中,需要存储的已不仅仅是简单的文字信息,同时还包 ...

  2. dbms_lob包学习笔记之三:instr和substr存储过程

    instr和substr存储过程,分析内部大对象的内容 instr函数与substr函数 instr函数用于从指定的位置开始,从大型对象中查找第N个与模式匹配的字符串. 用于查找内部大对象中的字符串的 ...

  3. Oracle学习笔记十四 内置程序包

    扩展数据库的功能 为 PL/SQL 提供对 SQL 功能的访问 用户 SYS 拥有所有程序包 是公有同义词 可以由任何用户访问 一些内置程序包 程序包名称 说明 STANDARD和DBMS_STAND ...

  4. DBMS_LOB

    1.LOB背景 在现在的系统开发中,需要存储的已不仅仅是简单的文字信息,也包括一些图片.音像资料或者超长的文本,这要求后台数据库具有存储这些数据的能力,Oracle通过提供LOB对象实现了该功能. 2 ...

  5. dbms_lob使用之-基础

     在Oracle中,存储在LOB中数据称为LOB的值,如使用Select   对某一LOB字段进行选择,则返回的不是LOB的值,而是该LOB字段的定位器(可以理解为指向LOB值的指针).如执行如下 ...

  6. [转载]DBMS_LOB

    1.LOB背景 在现在的系统开发中,需要存储的已不仅仅是简单的文字信息,也包括一些图片.音像资料或者超长的文本,这要求后台数据库具有存储这些数据的能力,Oracle通过提供LOB对象实现了该功能. 2 ...

  7. 在使用DBMS_LOB.WRITEAPPEND()追加Clob内容的时候,报数字或值异常

    在实际的使用中有可能会使用DBMS_LOB.WRITEAPPEND()去将Clob内容作为buffer增加到我们需要的对象中,但是在实际的使用中Clob大小往往是超过32767长度的,然而DBMS_L ...

  8. DBMS_LOB的简单用法以及释放DBMS_LOB生成的临时CLOB内存

    dbms_lob包(一) dbms_lob包(二) 如何释放DBMS_LOB.CREATETEMPORARY的空间 Temporary LOB导致临时表空间暴满. oracle数据库中的大对象1——永 ...

  9. 每周一书《Oracle 12 c PL(SQL)程序设计终极指南》

    本周为大家送出的书是<Oracle 12 c PL(SQL)程序设计终极指南>,此书由机械工业出版社出版, 孙风栋,王澜,郭晓惠 著. 内容简介: <Oracle 12c PL/SQ ...

随机推荐

  1. Dojo Mobile制定学习用品

    Dojo Mobile开展 App技术开发QQ群:347072638 技术咨询.APP定制开发联系邮箱:messageloop@qq.com 时代在演变.技术在革新.无论你接受不接受. 初识Dojo ...

  2. 为网站添加IE6升级提示

    原文 为网站添加IE6升级提示 IE6的是一款横跨十年的浏览器,作为一枚前端,对其已经失望透顶,但其在中国的市场比仍旧很高,中国大量的PC上安装的都是盗版Windows XP,而Windows XP上 ...

  3. ExecutorService invokeAll 实例(转)

    10个班级,每个班级20名学生,在指定的时间内查询每个班级学生的集合. package cn.com.ld.study.thread; import java.util.ArrayList; impo ...

  4. Git 1.9.5.msysgit.1

    Git 1.9.5.msysgit.1 发布,现已提供下载:https://github.com/msysgit/git/archive/v1.9.5.msysgit.1.zip. Git是一个开源的 ...

  5. MySQL汇总数据

    汇总数据 有时,数据本身是不上台面的操作数据表.但在摘要表中的数据.例如 数据的一列的平均值.极大值.至少值等一下. 对于这些频繁使用的数据的处理的概要,MySQL它提供了一个函数来处理. SQL聚集 ...

  6. stl之map容器的原理及应用

    容器的数据结构同样是采用红黑树进行管理,插入的元素健位不允许重复,所使用的节点元素的比较函数,只对元素的健值进行比较,元素的各项数据可通过健值检索出来.map容器是一种关联容器,实现了SortedAs ...

  7. React.js终探(六)

    在React中,我们怎么样使用它跟CSS 3 动画结合在一起使用呢? CSS3 Transitoin CSS3动画要求DOM属性变化的时候才能够被触发.所以这就需要我们把属性变化后的React元素渲染 ...

  8. Java 实现装饰(Decorator)模式

    在Java在.io反映非常多类包下是典型的装饰格局,例如: new BufferedOutputStream(OutputStream out) new BufferedInputStream(Inp ...

  9. 第一个JavaWeb程序

    转载 第一个JavaWeb程序 JavaWeb学习总结第二篇—第一个JavaWeb程序 最近我在学院工作室学习并加入到研究生的项目中,在学长学姐的带领下,进入项目实践中,为该项目实现一个框架(用已有框 ...

  10. mysql 数据库插入语句之insert into,replace into ,insert ignore

    近期才发现mysql的插入语句竟然有如此多的使用方法,这里拿来分享一下. ①关于insert into : insert into table_name values(); insert into t ...