在Java中处理CLOB字段

1.oracle driver的安装

因为操作oracle数据库,所以需要用到jdbc的驱动库,如果安装了oracle可以在oracle安装目下找到classes12.jar,将其拷贝到jdk的安装目录下(对于jdk与tomcat的安装可以在网上查查),以本人的实际安装目录为例:
(1)oracle版本9i:D:/oracle9/ora92/jdbc/lib  在此目录下可以找到classes12.jar
(2)jdk目录:C:/j2sdk1.4.1_04   将(1)中的classes12.jar拷到 C:/j2sdk1.4.1_04/jre/lib/ext目录下面

2.建立数据表
create table FILEINFO
(
  FILEID      INTEGER PRIMARY KEY,
  FILENAME    VARCHAR2(100),
  FILECONTENT CLOB
)

插入一条测试数据
insert into fileinfo values(1,'测试表',empty_clob());
3.具体实现我用eclipse为开发工具
(1)插入clob数据
import java.sql.*;
import oracle.jdbc.driver.*;
import oracle.sql.*;
import java.io.*;

public class putclob {

    /**
     * @param args
     */

    public static void main(String[] args) {
        // TODO Auto-generated method stub
        final String Webserver="192.168.36.32";//WEB服务器IP地址
        final String SID="ora92";//WEB数据库服务器SID
        final String UserID="****";//数据库用户名
        final String Password="****";//数据库密码
        final String sDBDriver = "oracle.jdbc.driver.OracleDriver";
        String sConnStr = "jdbc:oracle:thin:@"+Webserver+":1521:"+SID;
        Connection conn = null;
        Statement stmt=null;
        ResultSet rs = null;
        try
        {
          Class.forName(sDBDriver);
          conn = DriverManager.getConnection(sConnStr, UserID, Password);
          conn.setAutoCommit (false);
          String sql = "select * from fileinfo where fileid=1 for update";
          stmt = conn.createStatement();
          rs = stmt.executeQuery(sql);
            System.out.println("开始操作clob存入:");
          while(rs.next())
          {
             String str = "开始向表clob字段中存入数据";
            putclob g = new putclob();
             CLOB clob = (oracle.sql.CLOB) rs.getClob("filecontent");
            Writer outstream = clob.getCharacterOutputStream();
            outstream.write(str, 0, str.length());
            outstream.close();
            stmt.execute("commit");
            System.out.println("完毕:");
          }
          conn.setAutoCommit(true);
         
        }catch(Exception e){System.out.println(e.getMessage());}       
    }
}
(2)读取clob数据
import oracle.jdbc.driver.*;
import oracle.sql.*;
import java.sql.*;
import java.io.*;

public class getclob {

    /**
     * @param args
     */
    public String getClob(ResultSet rs,String colname) throws Exception
    {
    try{
        CLOB clob = (oracle.sql.CLOB) rs.getClob(colname);
        Reader instream = clob.getCharacterStream();
        char[] buffer = new char[1000];
        int length = 0;
        String Str="";
        while ((length = instream.read(buffer))!=-1)
            {
                Str=Str + new String(buffer,0,length);
            }
        instream.close();
        return Str;
    }catch(Exception e){System.out.println("opendb.getClob():" + e.getMessage());return "";}
    }
   
   
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        final String Webserver="192.168.36.32";//WEB服务器IP地址
        final String SID="ora92";//WEB数据库服务器SID
        final String UserID="techline";//数据库用户名
        final String Password="techline";//数据库密码
        final String sDBDriver = "oracle.jdbc.driver.OracleDriver";
        String sConnStr = "jdbc:oracle:thin:@"+Webserver+":1521:"+SID;
        Connection conn = null;
        Statement stmt=null;
        ResultSet rs = null;
        try
        {
          Class.forName(sDBDriver);
          conn = DriverManager.getConnection(sConnStr, UserID, Password);
          String sql = "select typeid,fileid,filename,filecontent from fileinfo";
          stmt = conn.createStatement();
          rs = stmt.executeQuery(sql);
          while(rs.next())
          {
            System.out.println(rs.getString("filename"));
             getclob g = new getclob();
            System.out.println("测试clob字段值:"+g.getClob(rs,"filecontent"));
          }
         
        }catch(Exception e){System.out.println(e.getMessage());}
    }
}

总结:在调试过程中出现了"无效的列类型: getCLOB not implemented for class oracle.jdbc.driver.T4CNumberAccessor "错误,经过查证是由于oracle的驱动问题,最开始我用的是10g的classes12.jar,后来用了9i的,此错误消失了.
在网上看到有介绍,在oracle10g中对于clob的操作更方便了(具体未查)

无论是delphi还是java操作clob字段的insert与select都是利用流来操作,这点都一样的(其它工具也如些).

你可能感兴趣的:(java,oracle,exception,String,import,数据库服务器)