C#读取BLOB数据学习经验

开发 后端
这里介绍C#读取BLOB数据要求工作在字节级。幸运的是,SqlDataReader 对象有一个 GetBytes 方法用于以字节方式访问一个列的数据。

在向大家详细介绍C#读取BLOB数据之前,首先让大家了解下什么是 BLOB?然后全面介绍C#读取BLOB数据。

什么是 BLOB?

BLOB 是二进制大对象(binary large object)的首字母缩写,是在 SQL Server 中作为一个单一实体存储的二进制数据集合。BLOB 主要用于保存多媒体对象,比如图像、视频和声音,但是它们还可以存储程序,甚至是代码片断。虽然 SQL Server 支持 BLOB,但不是所有数据都支持。

C#读取BLOB数据

有几种方法可以用来从 SQL Server 数据库读取数据。首先,你可以逐行读取数据;或者,你可以选择从特定列中读取数据。最简单的方法是访问特定的列,下面我们先讨论这种方法。

C#读取BLOB数据要求工作在字节级。幸运的是,SqlDataReader 对象有一个 GetBytes 方法用于以字节方式访问一个列的数据。一旦字节被读取,它们就可以与一个 FileStream 对象组合,以将 BLOB 对象保存到一个文件中。下面的 C#代码给出了这个例子:

  1. Byte[] blob = null;  
  2. FileStream fs = null;  
  3. const string sConn = "server=(local);Initial  
  4. Catalog=Northwind;UID=ctester;PWD=password";  
  5. try {  
  6. SqlConnection conn = new SqlConnection(sConn);  
  7. SqlCommand cmd = new SqlCommand("SELECT Picture FROM Categories WHERE  
  8. CategoryName='Builder'", conn);  
  9. cn.Open();  
  10. SqlDataReader sdr = cmd.ExecuteReader();  
  11. sdr.Read();  
  12.  
  13. blob = new Byte[(sdr.GetBytes(0, 0, null, 0, int.MaxValue))];  
  14. sdr.GetBytes[0, 0, blob, 0, blob.Length);  
  15. sdr.Close();  
  16. conn.Close();  
  17. fs = new FileStream("c:\\Builder.doc", FileMode.Create, FileAccess.Write);  
  18.  
  19. fs.Write(blob, 0, blob.Length);  
  20. fs.Close();  
  21. } catch (SqlException e){  
  22. Console.WriteLine("SQL Exception: " + e.Message);  
  23. } catch (Exception e) {  
  24. Console.WriteLine("Exception: "+ e.Message);  

【编辑推荐】

  1. C#方法重写全面介绍
  2. C#流程控制语句简单描述
  3. Java和C#字符串类型概述
  4. C#访问修饰符详细剖析
  5. 选择C#构造函数描述
责任编辑:佚名 来源: IT168
相关推荐

2009-09-01 13:10:39

C#读取Word

2009-08-19 16:36:29

C#管道技术

2009-08-19 10:25:18

C#托管资源

2009-08-13 18:13:27

C#学习经验

2009-08-27 14:44:11

C# interfac

2009-08-31 15:48:02

C# Singleto

2009-08-20 15:33:03

C#跳跃语句

2009-08-26 17:24:49

C# Mutex对象

2009-08-25 16:14:06

C#使用ADOX

2009-08-31 16:51:11

C# Main()方法

2009-08-27 09:27:49

C#扩展方法

2009-08-24 17:06:37

C#字符串

2009-08-28 16:43:57

C#多线程学习

2009-08-28 10:31:47

C#字符ASCII码

2009-08-11 14:20:41

C# .NET学习经验

2009-08-27 13:45:45

C#别名指示符

2009-08-12 15:55:12

C#接口定义

2009-09-04 14:01:30

C#存储BLOB对象

2009-08-24 16:02:10

C# Windows应

2009-08-24 17:34:14

C#创建XML Web
点赞
收藏

51CTO技术栈公众号