【转】ORACLE BLOB BFILE 文件的录入及读取
来源:互联网 发布:营销分析报告数据图表 编辑:程序博客网 时间:2024/06/06 02:55
如果你接触过mysql的话一定对mysql的text和blob不会陌生,在mysql中是直接操作text和blob的。但是在oracle中,它把lob做为一种特殊的字段,不能直接进行操作--比如不能直接插入到lob字段中,也不能用like查询等等。
这里是我保存的一篇这方面的文章,原文搬过来,由于保存的时候只是取了一部分,没头没尾的,所以没法找到原来的出处。
不能直接用INSERT语句向LOB字段中插入值。一般情况下,有如下的几步:
1 先分析一个INSERT语句,返回一个LOB的描述符
2 用OCI函数生成一个本地的LOB对象
3 将LOB对象绑定到LOB描述符上
4 执行INSERT语句
5 给LOB对象赋值
6 释放LOB对象和SQL语句句柄
下面的这个例子是把用户上传的图片文件存放到BLOB(或BFILE中,操作稍有不同)中。
首先要建一个表,结构如下:
CREATE TABLE PICTURES (
ID NUMBER,
DESCRIPTION VARCHAR2(100),
MIME VARCHAR2(128),
PICTURE BLOB
);
如果要实现ID的自动增加,再建一个SEQUENCE:
CREATE SEQUENCE PIC_SEQ;
然后是用来处理数据的PHP程序代码。
还有一个要注意的地方:LOB字段的值最少要1个字符,所以在save()或savefile()之前,要确保值不能为空。否则,Oracle会出错。
取出
对一个LOB中取出数据,有两种办法。一是生成一个LOB对象,然后绑定到一条SELECT语句返回的定位符上,再用LOB对象的load()方法取出数据;二是直接用PHP的OCIFetch***函数。第一种方法比第二种方法要麻烦得多,所以我直接说说第二种方法。
还是用上面的表。
这个程序用来显示放在LOB中的数据(图片)。调用方法(假设脚本名是getpicture.php):
<IMG SRC="getpicture.php?pictureid=99" ALT="放在Oracle LOB中的图片">
查询
前面已经提了下,对于Oracle的LOB字段是不能用LIKE进行匹配的。怎么办呢?其实并不复杂,Oracle有一个匿名的程序包,叫DBMS_LOB,里面有所有的操作LOB所需的过程。
假设有象这样一个表:
CREATE TABLE ARTICLES (
ID NUMBER,
TITLE VARCHAR2(100),
CONTENT CLOB
);
文章的内容放在CONTENT字段中。
现在我们要找出所以内容中包含"PHP中文用户"的文章,可以这么来做:
-----------------------------------------------------------------------------------------------------------------------------------------------------
这是我的测试成功结果,供大家参考!
- 【转】ORACLE BLOB BFILE 文件的录入及读取
- Oracle BLob 与BFile数据类型的区别
- oracle bfile blob
- oracle 操作bfile和blob
- oracle中的大对象BLOB,CLOB,BFILE
- oracle 中CLOB与BLOB、BFILE
- 如何读取Oracle的BLOB字段里的文件
- 如何读取Oracle的BLOB字段里的文件
- .NET中处理ORACLE大对象(CLOB,BLOB,BFILE)的开发
- Oracle与MySQL数据库大型对象类型(TinyBlob Blob Mediumblob LongBlob / BLOB CLOB NCLOB BFILE )的区别
- 【转】oracle对大对象类型操作:blob,clob,nclob,bfile
- 关于oracle中blob字段的录入问题
- oracle对大对象类型操作:blob,clob,nclob,bfile
- oracle对大对象类型操作:blob,clob,nclob,bfile
- oracle对大对象类型操作:blob,clob,nclob,bfile
- oracle中blob,clob,nclob,Bfile主要区别是什么? .
- oracle对大对象类型操作:blob,clob,nclob,bfile
- oracle中blob,clob,nclob,Bfile主…
- 雷军:为什么马云马化腾创业那么容易成功 自己却需要煎熬数年
- 《赢取竞争的100+N工具箱》
- Java Servlet Filter实现Web页面执行时间过滤器
- (转)免费经济学---为什么我喜欢互联网
- 第六章 键盘part2
- 【转】ORACLE BLOB BFILE 文件的录入及读取
- 个人主页FLASH网站源码(FLASH+HTML+PSD+字体)[ym1z090903]
- Java TagSupport实现Web权限验证标签
- 在VLC控件中添加接口的方法
- 使用系统自带皮肤
- Java 小例子:行列式和鸡兔同笼问题
- 使用自定义皮肤
- 2009年上海市高效照明推广产品售后服务点名单
- GetAdaptersAddresses Function