中国IT动力,最新最全的IT技术教程
最新100篇 | 推荐100篇 | 专题100篇 | 排行榜 | 搜索 | 在线API文档
首 页 | 程序开发 | 操作系统 | 软件应用 | 图形图象 | 网络应用 | 精文荟萃 | 教育认证 | 硬件维护 | 未整理篇 | 站长教程
ASP JS PHP工程 ASP.NET 网站建设 UML J2EESUN .NET VC VB VFP 网络维护 数据库 DB2 SQL2000 Oracle Mysql
服务器 Win2000 Office C DreamWeaver FireWorks Flash PhotoShop 上网宝典 CorelDraw 协议大全 网络安全 微软认证
硬件维护  CPU  主板  硬盘  内存  显卡  显示器  键盘鼠标  声卡音箱  打印机  机箱电源  BIOS  网卡  C#  Java  Delphi  vs.net2005
  当前位置:> 程序开发 > 数据库开发 > 数据库综合
.net中二进制大对象的操作
作者:佚名 时间:2004-07-08 10:40 出处:互连网 责编:chinaitpower
              摘要:.net中二进制大对象的操作

    public static void WriteLob(string table_name,string table_id,int id,int column,string content)
     {
      OracleConnection myCn = new OracleConnection(strConn);   
      OracleCommand myCmd = new OracleCommand();
      try
      {
       myCn.Open();    
      }
      catch(System.Data.OracleClient.OracleException e)
      {
       throw new Exception(e.Message);
      }   
      OracleTransaction myTrans = myCn.BeginTransaction();
      try
      {           
       myCmd.Connection = myCn;    
       myCmd.Transaction = myTrans;
       myCmd.CommandText = "SELECT * FROM "+ table_name +" where "+ table_id +" = "+ id +" FOR UPDATE";
       OracleDataReader reader = myCmd.ExecuteReader();
       using(reader)
       {
        reader.Read();
        OracleLob CLOB = reader.GetOracleLob(column);//column为lob类型所在列
        Encoding UTF8 = Encoding.UTF8;        //使用UTF-8进行编码
        byte[] buffer = UTF8.GetBytes(content);
        if(buffer.Length % 2 ==0)
         CLOB.Write(buffer, 0, buffer.Length);  //这里的参数必须为偶数
        else
         CLOB.Write(buffer, 0, (buffer.Length - 1));
        //CLOB.Position = 0;
        myTrans.Commit();
       }
      }
      catch(System.Data.OracleClient.OracleException e)
      {   
       myTrans.Rollback();
       throw new Exception(e.Message);
      }
      finally
      {
       myCmd.Dispose();
       myCn.Close();
      }
     }
     public static string ReadLob(string table_name,string table_id,int id,int column)
     {
      OracleConnection myCn = new OracleConnection(strConn);   
      OracleCommand myCmd = new OracleCommand();
      try
      {
       myCn.Open();    
      }
      catch(System.Data.OracleClient.OracleException e)
      {
       throw new Exception(e.Message);
      }   
      OracleTransaction myTrans = myCn.BeginTransaction();
      try
      {           
       myCmd.Connection = myCn;    
       myCmd.Transaction = myTrans;
       myCmd.CommandText = "SELECT * FROM "+ table_name +" where "+ table_id +" = "+ id +" FOR UPDATE";
       OracleDataReader reader = myCmd.ExecuteReader();
       using(reader)
       {
        reader.Read();
        OracleLob CLOB = reader.GetOracleLob(column);
        int[] content = new int[(int)CLOB.Length];
        byte[] buffer = new byte[(int)CLOB.Length];
         
        for(int i = 0;i<(int)CLOB.Length;i++)
        {
         content = CLOB.ReadByte();
         buffer = (byte)content;
        }
   
        Encoding utf8 = Encoding.UTF8;
        
        string final = utf8.GetString(buffer);
        myTrans.Commit();
        return final;
       }
      }
      catch(System.Data.OracleClient.OracleException e)
      {   
       myTrans.Rollback();
       throw new Exception(e.Message);
      }
      finally
      {
       myCmd.Dispose();
       myCn.Close();
      }
     }
关闭本页
 
首页 | 投资与合作 | 服务条款 | 隐私政策 | 收藏本站 | 设为首页 | 新用户注册 | 免责声明 | 使用帮助
Copyright ©2005-2008 chinaitpower.com All rights reserved. www.chinaitpower.com 版权所有