设为首页 收藏本站
查看: 592|回复: 0

[经验分享] Oracle中BLOB和CLOB字段的操作

[复制链接]

尚未签到

发表于 2016-8-4 13:31:27 | 显示全部楼层 |阅读模式
一、区别和定义
       LONG: 可变长的字符串数据,最长2G,LONG具有VARCHAR2列的特性,可以存储长文本一个表中最多一个LONG列
  LONG RAW: 可变长二进制数据,最长2G
  CLOB: 字符大对象Clob 用来存储单字节的字符数据
  NCLOB: 用来存储多字节的字符数据
  BLOB: 用于存储二进制数据
  BFILE: 存储在文件中的二进制数据,这个文件中的数据只能被只读访。但该文件不包含在数据库内。
        bfile字段实际的文件存储在文件系统中,字段中存储的是文件定位指针.bfile对oracle来说是只读的,也不参与事务性控制和数据恢复.
  
  CLOB,NCLOB,BLOB都是内部的LOB(Large Object)类型,最长4G,没有LONG只能有一列的限制
  要保存图片、文本文件、Word文件各自最好用哪种数据类型?
  --BLOB最好,LONG RAW也不错,但Long是oracle将要废弃的类型,因此建议用BLOB。
二、操作
1、 get
CLOB
java 代码
//获得数据库连接   
Connection con = ConnectionFactory.getConnection();   
con.setAutoCommit(false);   
Statement st = con.createStatement();   
//不需要“for update”   
ResultSet rs = st.executeQuery("select CLOBATTR from TESTCLOB where ID=1");   
if (rs.next())   
{   
java.sql.Clob clob = rs.getClob("CLOBATTR");   
Reader inStream = clob.getCharacterStream();   
char[] c = new char[(int) clob.length()];   
inStream.read(c);   
//data是读出并需要返回的数据,类型是String   
data = new String(c);   
inStream.close();   
}   
inStream.close();   
con.commit();   
con.close();   

BLOB
java 代码
//获得数据库连接   
Connection con = ConnectionFactory.getConnection();   
con.setAutoCommit(false);   
Statement st = con.createStatement();   
//不需要“for update”   
ResultSet rs = st.executeQuery("select BLOBATTR from TESTBLOB where ID=1");   
if (rs.next())   
{   
java.sql.Blob blob = rs.getBlob("BLOBATTR");   
InputStream inStream = blob.getBinaryStream();   
//data是读出并需要返回的数据,类型是byte[]   
data = new byte[input.available()];   
inStream.read(data);   
inStream.close();   
}   
inStream.close();   
con.commit();   
con.close();   
2、 put
CLOB
java 代码
//获得数据库连接   
Connection con = ConnectionFactory.getConnection();   
con.setAutoCommit(false);   
Statement st = con.createStatement();   
//插入一个空对象empty_clob()   
st.executeUpdate("insert into TESTCLOB (ID, NAME, CLOBATTR) values (1, "thename", empty_clob())");   
//锁定数据行进行更新,注意“for update”语句   
ResultSet rs = st.executeQuery("select CLOBATTR from TESTCLOB where ID=1 for update");   
if (rs.next())   
{   
//得到java.sql.Clob对象后强制转换为oracle.sql.CLOB   
oracle.sql.CLOB clob = (oracle.sql.CLOB) rs.getClob("CLOBATTR");   
Writer outStream = clob.getCharacterOutputStream();   
//data是传入的字符串,定义:String data   
char[] c = data.toCharArray();   
outStream.write(c, 0, c.length);   
}   
outStream.flush();   
outStream.close();   
con.commit();   
con.close();   

BLOB
java 代码
//获得数据库连接   
Connection con = ConnectionFactory.getConnection();   
con.setAutoCommit(false);   
Statement st = con.createStatement();   
//插入一个空对象empty_blob()   
st.executeUpdate("insert into TESTBLOB (ID, NAME, BLOBATTR) values (1, "thename", empty_blob())");   
//锁定数据行进行更新,注意“for update”语句   
ResultSet rs = st.executeQuery("select BLOBATTR from TESTBLOB where ID=1 for update");   
if (rs.next())   
{   
//得到java.sql.Blob对象后强制转换为oracle.sql.BLOB   
oracle.sql.BLOB blob = (oracle.sql.BLOB) rs.getBlob("BLOBATTR");   
OutputStream outStream = blob.getBinaryOutputStream();   
//data是传入的byte数组,定义:byte[] data   
outStream.write(data, 0, data.length);   
}   
outStream.flush();   
outStream.close();   
con.commit();   
con.close();

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-252793-1-1.html 上篇帖子: oracle时间相减及带时间间隔的SQL 下篇帖子: Oracle listener静态注册和动态注册研究
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表