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

Oracle认证
Oracle9I OCP认证过程
常见的一些Oracle初学者的问题
ORACLE认证系统概述
数据库考试简介:Oracle认证
Oracle认证基础知识介绍
如何从一名DBA初学者变为中级水平的DBA?
如何从一名中级的DBA转变为高级DBA?
怎样在Oracle 9i中正确的转换时区
RHEL AS4上安装oracle 10R2 的方法
解决Oracle并行服务器的相关问题
正确进行Oracle数据库性能完全保护
最影响Oracle系统性能的初始化参数
详细介绍Oracle数据库的启动和关闭
Oracle实现自增型ID和删除重复记录
Oracle静态注册和动态注册
Oracle数据更改后出错
Oracle10G认证考试自2008年12月1日变化
什么是Oracle?oracle认证种类介绍
解决Orcale与Asp.net的端口冲突
oracle认证辅导:重访Oracle密码

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-04   浏览: 312 ::
收藏到网摘: 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中开发并调试通过。