.net中二进制大对象的操作(这里以clob为例)

25 篇文章 0 订阅

 .net中二进制大对象的操作(这里以clob为例)

    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();
       }
     }
 
经测试通过,相信对有些朋友会有帮助的。

在读记录时
for(int i = 0;i<(int)clob.Length;i++)
           {
             content = clob.ReadByte();
             buffer  = (byte)content;
           }
读取太慢
用了clob.read(buffer,0,clob.length);
直接把记录读取buffer中,速度很快。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值