相关知识:

  1. 在SQL Server中,一般情况下,每行数据的总长度不能超过8K字节。因此,下列数据类型的长度,也不能超过8K字节:binary,char(),nchar(),varchar(),nvarchar()。注意,由于nvarchar是Unicode字符,因此,其最大长度也不能超过nvarchar(4000)
  2. 对于超长数据,尤其是二进制数据(例如音频视频数据等),SQL Server提供了下列数据类型(可以超过8K):image,varbinary(max),text,ntext,varchar(max),nvarchar(max)
  3. 对于较小的二进制数据,可以公国DataReader或者DataSet一次性读取。但是对于较大的二进制数据(BLOB),例如1MB以上,如果一次性把所有数据都读取出来,就会消耗大量的程序内存(字节数组)。因此,往往是采用分批读取的方式进行
  4. SqlDataReader的二进制读取:
    • 在ExecuteReader调用时,要指定CommandBehavior.SequentialAccess选项,以表明通过顺序的方式逐段读取

       SqlDataReader dr = cmd.ExecuteReader(CommandBehavior.SequentialAccess);
    • GetBytes函数,可以将二进制字段中的数据逐段读到缓冲区中
    • 应当优先把BLOB字段前的其他字段读取出来,否则一旦开始读BLOB字段,将无法再回头去读之前的字段

代码示例:

  • 数据库:采用红皮书的示例数据库,AdventureWorks_WroxSSRS2012,使用Production.ProductPhoto表,获取其中的图片数据信息

   

  • 引入:

    using System.Data;
    using System.Data.SqlClient;
    using System.IO;
  • 基本定义:

             const int BUF_SIZE = ;//缓冲区大小
    static string strConn = @"server=Joe-PC;database=AdventureWorks_WroxSSRS2012;uid=sa;pwd=root";
    static SqlConnection conn = new SqlConnection(strConn);
    //优先把BLOB字段前的其他字段读取出来,否则一旦开始读BLOB字段,将无法再回头去读之前的字段(注意此sql语句中字段的顺序与数据库字段顺序的对比)
    static string strCmd = "SELECT ProductPhotoID,ThumbnailPhotoFileName,ThumbNailPhoto,LargePhotoFileName,LargePhoto FROM Production.ProductPhoto";
    static SqlCommand cmd = new SqlCommand(strCmd, conn);
  • 访问ProductPhoto表
             static void Main(string[] args)
    {
    try
    {
    conn.Open();
    //以SequentialAccesss方式打开DataReader
    SqlDataReader dr = cmd.ExecuteReader(CommandBehavior.SequentialAccess);
    while (dr.Read())
    {
    int productPhotoID = dr.GetInt32();
    string thumbnailPhotoFileName = dr.GetString();//读取缩略图文件名
    WriteThumbnailPhotoFile(thumbnailPhotoFileName, dr);//将缩略图二进制数据写入磁盘文件
    string largePhotoFileName = dr.GetString();//读取大图文件名
    WriteLargePhotoFile(largePhotoFileName, dr);//将大图二进制数据写入磁盘文件
    }
    }
    catch (Exception e)
    {
    Console.WriteLine(e);
    }
    finally
    {
    conn.Close();
    }
    }
  • 将缩略图二进制数据写入磁盘文件的函数
             static void WriteThumbnailPhotoFile(string fileName, SqlDataReader dr)
    {
    string path = "..\\..\\images\\Thumbnail\\" + fileName;//需要预先在项目文件夹中建立此目录
    FileStream fs = new FileStream(path, FileMode.Create, FileAccess.Write);
    //ThumbnailPhoto的数据比较小(没有超过8KB),因此选择一次性读出,直接写入文件
    byte[] buf = dr[] as byte[];
    fs.Write(buf, , buf.Length);
    fs.Close();
    }
  • 将大图二进制数据写入磁盘文件的函数
             static void WriteLargePhotoFile(string fileName, SqlDataReader dr)
    {
    string path = "..\\..\\images\\Large\\" + fileName;//需要预先在项目文件夹中建立此目录
    FileStream fs = new FileStream(path, FileMode.Create, FileAccess.Write);
    byte[] buf = new byte[BUF_SIZE];
    long bytesRead = ;
    long startIndex = ;
    //LargePhoto的数据比较大,因此分批次读出,分别写入文件
    while ((bytesRead = dr.GetBytes(, startIndex, buf, , BUF_SIZE)) > )
    {
    fs.Write(buf, , (int)bytesRead);
    startIndex += bytesRead;
    }
    fs.Close();
    }

程序说明:

需要预先在本项目文件夹下建立images目录,内有thumbnail和large子目录,用于存放从数据库获取的图片

ADO.NET笔记——读取二进制大对象(BLOB)的更多相关文章

  1. ADO.NET笔记——存储二进制大对象(BLOB)

    相关知识 上传二进制大对象(Binary Large Object)(如图片.视频等)的基本编程步骤是: 在数据库中使用varbinary(MAX).varchar(MAX)或者nvarchar(MA ...

  2. ADO学习笔记之注入漏洞与参数化查询

    ADO学习笔记之注入漏洞与参数化查询 作为新手,在学习ADO程序时,使用 sql 语言查询数据时,很容易写类似如下代码: using (SqlConnection con = new SqlConne ...

  3. ADO.NET笔记20160322

    ####ADO.NET ####1 启用sa验证与窗体相关知识     - 启用sa验证     - ShowDialog() ---- ####2 连接字符串     Data Source=服务器 ...

  4. ADO.net笔记

    1.DbConnectionConnection对象也称为数据库连接对象,Connection对象的功能是负责对数据源的连接.所有Connection对象的基类都是DbConnection类.Conn ...

  5. 10.4(java学习笔记)CLOB,BLOB基本操作

    一.CLOB 1.1CLOB简介 CLOB全称是(Character Large Object)字符大对象,用于存储大量的文本数据. 字符大对象的操作不同于一般数据,是通过流来完成的. 1.2MySQ ...

  6. ADO.NET(OleDb)读取Excel表格时的一个BUG

    如果我们有例如以下一个Excel表格:    如今要使用C#程序读取其内容: using System;  using System.Data.OleDb;    namespace Skyiv.Be ...

  7. python3笔记-读取ini配置文件

    在代码中经常会通过ini文件来配置一些常修改的配置.下面通过一个实例来看下如何写入.读取ini配置文件. 需要的配置文件是: [path] back_dir = /Users/abc/PycharmP ...

  8. Ado.net 数据库读取文件

    string connStr = ConfigurationManager.ConnectionStrings["connStr"].ConnectionString; using ...

  9. FPGA笔记-读取.dat文件

    读取.dat图像文件 .dat文件是matlab生成的图像文件 initial begin // Initialize Inputs CLK = 0; RST = 1; IMAGE_DATA = 0; ...

随机推荐

  1. ZOJ 2588 Burning Bridges(求含重边的无向连通图的割边) - from lanshui_Yang

    Burning Bridges Time Limit: 5 Seconds Memory Limit: 32768 KB Ferry Kingdom is a nice little country ...

  2. 来自 Github 的图形化 Git 使用教程

    转载:http://www.linuxeden.com/html/news/20120628/126451.html 这是来自 Github 上对 Git 常用操作进行简短介绍以及可视化图形操作说明的 ...

  3. 关于h5手机端上拉加载和下拉刷新效果-1

    1.手机端目前很火的效果,上拉加载,和下拉刷新.目前主要使用 iscroll 框架来实现.先推荐一个iscroll中文学习的网站,不要感谢,我是雷锋. 2.https://iiunknown.gitb ...

  4. .NET 托管堆和垃圾回收

       托管堆基础 简述:每个程序都要使用这样或那样的资源,包括文件.内存缓冲区.屏幕空间.网络连接.....事实上,在面向对象的环境中,每个类型都代表可供程序使用的一种资源.要使用这些资源,必须为代表 ...

  5. ImageView的Scaletype

    ImageView的Scaletype决定了图片在View上显示时的样子,如进行何种比例的缩放,及显示图片的整体还是部分,等等. 设置的方式包括: 1. 在layout xml中定义android:s ...

  6. 基于 Equinox 的 OSGi Console 的研究和探索

    自定制 OSGi Console 进行组建和服务生命周期管理模块化编程的好处已经很好地被理解了约 40 年,但在 OSGi 之前,开发人员不得不自己发明模块化设计和系统.随着软件应用体系结构的不断发展 ...

  7. Android 高级UI设计笔记10:瀑布流控件PinterestLikeAdapterView的使用

    1. 首先我们看看瀑布流的效果,如下: 2. 今天要介绍的瀑布流控件是:PinterestLikeAdapterView 项目地址:https://github.com/GDG-Korea/Pinte ...

  8. Java基础知识强化之多线程笔记06:Lock接口 (区别于Synchronized块)

    1. 简介 我们讲到了如何使用关键字synchronized来实现同步访问.本文我们继续来探讨这个问题,从Java 5之后,在java.util.concurrent.locks包下提供了另外一种方式 ...

  9. eclipse启动问题

    今天在公司正上班,突然跳出来一个windows update补丁更新,然后就确认呗,结果更新完成之后, eclipse打不开了,启动报错: could not find the main class, ...

  10. 20145102 《Java程序设计》第2周学习总结

    20145102 <Java程序设计>第2周学习总结 教材学习内容总结 这章先介绍了基本类型,和其他语言相似,分为short整数(2字节).int整数(4字节).long整数(8字节).f ...