oracle字段类型blob,clob,nclob

    三种大型对象(LOB),用来保存较大的图形文件或带格式的文本文件,如Miceosoft Word文档,以及音频、视频等非文本文件,最大长度是4GB。LOB有几种类型,取决于你使用的字节的类型,Oracle 8i实实在在地将这些数据存储在数据库内部保存。可以执行读取、存储、写入等特殊操作。 我们所操作的clobtest_table中属性是(字符型id,CLOB型picstr),目前我们假设一个大的字符对象str已经包含了我们需要存入picstr字段的数据。而且connection对象conn已经建立。以下的例子程序也因为不想占用太多的空间,所以对抛出异常没有写。大家参考一下api doc。就可以知道该抛出什么异常了,此处仅仅告诉大家如何去写。 

  代码: 
   
   
  (1)对数据库clob型执行插入操作 
  ************************************************* 
   
  java.sql.PreparedStatement pstmt = null; 
  ResultSet rs = null; 
  String query = ""; 
   
  conn.setAutoCommit(false); 
   query = "insert into clobtest_table(id,picstr) values(?,empty_clob())"; 
  java.sql.PreparedStatement pstmt = conn.prepareStatement(query); 
  pstmt.setString(1,"001"); 
  pstmt.executeUpdate(); 
  pstmt = null 
   query = "select picstr from clobtest_table where id = '001' for update"; 
  pstmt = con.prepareStatement(query) 
  rs= pstmt.executeQuery(); 
   
  oracle.sql.CLOB clobtt = null; 
  if(rs.next()){ 
   clobtt = (oracle.sql.CLOB)rs.getClob(1); 
  } 
  Writer wr = clobtt.getCharacterOutputStream(); 
  wr.write(strtmp); 
  wr.flush(); 
  wr.close(); 
  rs.close(); 
  con.commit(); 
   
   
   
  (2)通过sql/plus查询是否已经成功插入数据库 
  ************************************************* 
   
  PL/SQL的包DBMS_LOB来处理LOB数据。察看刚才的插入是否成功。使用DBMS_LOB包的getlength这个procedure来检测是否已经将str存入到picstr字段中了。如: 
   
  SQL> select dbms_lob.getlength(picstr) from clobtest_table; 
   
   
  (3)对数据库clob型执行读取操作 
  ************************************************* 
   
  读取相对插入就很简单了。基本步骤和一半的取数据库数据没有太大的差别。 
  String description = "" 
   query = "select picstr from clobtest_table where id = '001'"; 
  pstmt = con.prepareStatement(query); 
  ResultSet result = pstmt.executeQuery(); 
  if(result.next()){ 
   oracle.jdbc.driver.OracleResultSet ors = 
   (oracle.jdbc.driver.OracleResultSet)result; 
   oracle.sql.CLOB clobtmp = (oracle.sql.CLOB) ors.getClob(1); 
   
   if(clobtmp==null || clobtmp.length()==0){ 
   System.out.println("======CLOB对象为空 "); 
   description = ""; 
   }else{ 
   description=clobtmp.getSubString((long)1,(int)clobtmp.length()); 
   System.out.println("======字符串形式 "+description); 
   } 
  } 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Oracle数据库中的BLOBCLOB是用来存储大数据(二进制大对象和字符大对象)的数据类型BLOB可以存储二进制数据,如图片、音频和视频等,而CLOB则用于存储文本数据。 要导出BLOBCLOB数据,可以使用Oracle数据库提供的工具和方法。以下是一种常见的导出方法: 1. 使用 Oracle SQL Developer 进行导出: - 打开 Oracle SQL Developer 工具,并连接到要导出的数据库。 - 在“工具栏”上选择“导出数据”选项。 - 在导出向导中,选择要导出的表并指定目标文件夹。 - 在“导出格式”下,选择“BLOB”或“CLOB”。 - 点击“下一步”并根据导出设置完成导出过程。 要导入BLOBCLOB数据,也可以使用类似的方法: 1. 使用 Oracle SQL Developer 进行导入: - 打开 Oracle SQL Developer 工具,并连接到要导入的数据库。 - 在“工具栏”上选择“导入数据”选项。 - 在导入向导中,选择要导入的表和数据文件。 - 在“导入格式”下,选择“BLOB”或“CLOB”。 - 点击“下一步”并根据导入设置完成导入过程。 此外,还可以使用PL/SQL语言编写脚本来导出和导入BLOBCLOB数据。使用PL/SQL可以更灵活地进行数据处理和转换。可以编写一段脚本来查询BLOBCLOB数据,并将其导出到文件中,然后在另一个数据库上运行脚本来导入数据。 总之,Oracle数据库提供了多种方法来导出和导入BLOBCLOB数据。使用这些方法,可以方便地将大数据对象从一个数据库迁移到另一个数据库。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值