新书推介:《语义网技术体系》
作者:瞿裕忠,胡伟,程龚
   XML论坛     W3CHINA.ORG讨论区     计算机科学论坛     SOAChina论坛     Blog     开放翻译计划     新浪微博  
 
  • 首页
  • 登录
  • 注册
  • 软件下载
  • 资料下载
  • 核心成员
  • 帮助
  •   Add to Google

    >> 本版讨论.NET,C#,ASP,VB技术
    [返回] 中文XML论坛 - 专业的XML技术讨论区计算机技术与应用『 Dot NET,C#,ASP,VB 』 → 用 C# 编程实现读写Binary 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 3903 个阅读者浏览上一篇主题  刷新本主题   树形显示贴子 浏览下一篇主题
     * 贴子主题: 用 C# 编程实现读写Binary 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     卷积内核 帅哥哟,离线,有人找我吗?
      
      
      威望:8
      头衔:总统
      等级:博士二年级(版主)
      文章:3942
      积分:27590
      门派:XML.ORG.CN
      注册:2004/7/21

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给卷积内核发送一个短消息 把卷积内核加入好友 查看卷积内核的个人资料 搜索卷积内核在『 Dot NET,C#,ASP,VB 』的所有贴子 访问卷积内核的主页 引用回复这个贴子 回复这个贴子 查看卷积内核的博客楼主
    发贴心情 用 C# 编程实现读写Binary

    本文给出一个用 C# 编程实现读写 Binary 的实例代码,对于初学者来说是个不可多得的参考性文章……

    以下是引用片段:
      //返回blob数据
      public MemoryStream getBlob(string SQL)
      ...{
      try
      ...{
      Db_Conn();
      cmd = new OleDbCommand(SQL, Conn);
      cmd.CommandType = CommandType.Text;//是sql
      OleDbDataReader Rs = cmd.ExecuteReader();
      if (Rs.Read()) //循环到下一条记录
      ...{
      if (!(Rs.GetValue(0) is System.DBNull))
      ...{
      byte[] image_bytes = (byte[])Rs.GetValue(0);
      MemoryStream ms = new MemoryStream(image_bytes);
      return ms;
      }
      else
      return null;
      }
      else
      return null;
      }
      finally
      ...{
      this.close();
      }
      }
      //设置blob
      public bool SetBlob(string SQL, MemoryStream Ms)
      ...{
      try
      ...{
      Db_Conn();
      cmd = new OleDbCommand(SQL, Conn);
      cmd.CommandType = CommandType.Text;//是sql
      int n=Convert.ToInt32(Ms.Length.ToString());
      Ms.Position = 0;
      byte[] pReadByte = new Byte[n];
      Ms.Read(pReadByte, 0, n);
      cmd.Parameters.Add("BLOB", OleDbType.Binary).Value = pReadByte;
      cmd.ExecuteNonQuery();
      return true;
      }
      catch (Exception ex)
      ...{
      MessageBox.Show("错误:因" + ex.Message + ",无法执行:" + SQL);
      return false;
      }
      finally
      ...{
      this.close();
      }
      }


      调用 getBlob

    以下是引用片段:
      String sqlStr = "select content from dp where id=" + ID;//content为dp中的BLOB字段,ID为主键
      MemoryStream ms = DBClass.getBlob(sqlStr);
      if (ms == null)
      richTextBox.Clear();
      else
      ...{
      if (ms.Length > 0)
      ...{
      ms.Position = 0;
      try
      ...{
      richTextBox.LoadFile(ms, RichTextBoxStreamType.RichText);
      }catch...{
      richTextBox.LoadFile(ms, RichTextBoxStreamType.PlainText);
      }
      }else
      richTextBox.Clear();
      }


      调用setBlob

    以下是引用片段:
      String sqlStr = "update dp set content=:BLOB where id=" + ID;
      MemoryStream ms = new MemoryStream();
      richTextBox.SaveFile(ms, RichTextBoxStreamType.RichText);
      if (!DBClass.SetBlob(sqlStr, ms))
      ...{
      MessageBox.Show("保存失败");
      }


       收藏   分享  
    顶(0)
      




    ----------------------------------------------
    事业是国家的,荣誉是单位的,成绩是领导的,工资是老婆的,财产是孩子的,错误是自己的。

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2009/7/9 15:10:00
     
     GoogleAdSense
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 Dot NET,C#,ASP,VB 』的所有贴子 访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2024/12/27 2:28:56

    本主题贴数1,分页: [1]

    管理选项修改tag | 锁定 | 解锁 | 提升 | 删除 | 移动 | 固顶 | 总固顶 | 奖励 | 惩罚 | 发布公告
    W3C Contributing Supporter! W 3 C h i n a ( since 2003 ) 旗 下 站 点
    苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》
    47.852ms