当前位置: 首页 > 图文教程 > 数据库 > Oracle > 使用Java和oracle实现BLOB字段的字符串读取

Oracle
如何从Oracle 9i SQL*Loader中生成外部表定义
简单冷备份恢复操作步骤
解决ASM无法启动问题
将Oracle的数据导入EXCEL中的方法
Oracle数据库在线备份原理
利用SQL * Plus复制遗留的Oracle数据表
分析Oracle下导出某用户所有表的方法
利用SQL *Plus复制遗留的Oracle数据表
解决Oracle下的undo空间过大的问题
如何使用Oracle 10gR2's RMAN进行加密备份
利用多个转储文件导出大量Oracle数据
用Rsync备份Dreamhost 到Windows 上
从Access 2000数据库转移到Oracle 9i
利用Oracle执行计划机制提高查询性能
Oracle的自动数据库诊断监控程序剖析
教你Oracle的数据缓冲区是如何工作
Oracle DBA数据库日常维护完全手册
合理设置数据库以提高查询统计速度
Oracle数据库数据锁定机制全面解析
DBA 应遵循的 Oracle 调优原则

Oracle 中的 使用Java和oracle实现BLOB字段的字符串读取


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-30   浏览: 213 ::
收藏到网摘: n/a

  java能够调用Oracle的存储过程,反之oracle也能用java来开发外部存储过程,这样java和oracle的相互界限就已经不明确了。
  当然关系型数据库最好做自己应该做的事情而不是大包大揽做所有的非数据库应该做的事情。
  ——开发java类
  create or replace and compile java source named BLOBObject as
  package MyOracle.BLOB; --自己定义的package
  import java.io.*; --外部引用到的java包
  import oracle.sql.*;
  public class BLOBObject
  {
  public static String ConvertBLOBtoString(oracle.sql.BLOB BlobContent)
  {
  byte[] msgContent= BlobContent.getBytes(); //BLOB转换为字节数组
  byte[] bytes; //BLOB临时存储字节数组
  String newStr = ""; //返回字符串
  int i=1; //循环变量
  long BlobLength; //BLOB字段长度
  try
  {
  BlobLength=BlobContent.length(); //获取BLOB长度
  if (msgContent == null || BlobLength==0) //如果为空,返回空值
  {
  return "";
  }
  else //处理BLOB为字符串
  {
  /*
  while(i
  {
  bytes= BlobContent.getBytes(i,1024) ;
  i=i+1024;
  newStr = newStr+new String(bytes,"gb2312";
  }
  */
  newStr = new String(BlobContent.getBytes(1,900),"gb2312"+"...."; //简化处理,只取前900字节
  return newStr;
  }
  }
  catch(Exception e) //oracle异常捕获
  {
  e.printStackTrace();
  }
  return newStr;
  }
  }
  ——然后在Oracle中把这个类导入成为一个函数,执行命令
  create or replace function ConvertBLOB(blobObject BLOB)
  return varchar2
  as language java name
  'MyOracle.BLOB.BLOBObject.ConvertBLOBtoString(oracle.sql.BLOB) return java.lang.String';
  ——执行相应的操作
  select ConvertBLOB(BLOBField),dbms_lob.getlength(BLOBField),BLOBFieldfrom TableName
  以上代码均在PL/SQL developer中开发并调试通过。