该例子是一个对SQL Server数据类型的一个操作例子,具有写入、读取功能。

1:准备数据库

1)创建数据库 Test

2)创建表 Table_1 (分别有2个字段:id(Int)、photo(Image))

如图:

2:用C#进行读写操作,完整代码如下:

[csharp] view
plain
 copy

print?

  1. using System;
  2. using System.Collections.Generic;
  3. using System.ComponentModel;
  4. using System.Data;
  5. using System.Drawing;
  6. using System.Linq;
  7. using System.Text;
  8. using System.Windows.Forms;
  9. using System.Data.SqlClient;
  10. using System.IO;
  11. namespace imageTest
  12. {
  13. public partial class Form1 : Form
  14. {
  15. public Form1()
  16. {
  17. InitializeComponent();
  18. }
  19. private void btn_brewse_Click(object sender, EventArgs e)
  20. {
  21. OpenFileDialog op = new OpenFileDialog();
  22. op.Title = "浏览图像文件";
  23. op.Filter = "图像文件(*.jpg)|*.jpg";
  24. op.ShowDialog();
  25. txt_ImageAddress.Text = op.FileName;
  26. }
  27. private void btn_Insert_Click(object sender, EventArgs e)
  28. {
  29. FileStream fs = new FileStream(txt_ImageAddress.Text,FileMode.Open,FileAccess.Read);
  30. byte[] byteArray = new byte[fs.Length];
  31. fs.Read(byteArray,0,Convert.ToInt32(fs.Length));
  32. fs.Close();
  33. string connectionStr = "Server=.;Database=Test;Uid=sa;Pwd=123456";
  34. SqlConnection conn = new SqlConnection(connectionStr);
  35. conn.Open();
  36. SqlCommand cmd = new SqlCommand("INSERT INTO Table_1(photo) VALUES(@photo)",conn);
  37. SqlParameter parmeter = new SqlParameter("@photo", SqlDbType.Image);
  38. parmeter.Value = byteArray;
  39. cmd.Parameters.Add(parmeter);
  40. int result = cmd.ExecuteNonQuery();
  41. if (result > 0)
  42. MessageBox.Show("插入成功");
  43. conn.Close();
  44. }
  45. private void btn_ReadImage_Click(object sender, EventArgs e)
  46. {
  47. string connectionStr = "Server=.;Database=Test;Uid=sa;Pwd=123456";
  48. SqlConnection conn = new SqlConnection(connectionStr);
  49. conn.Open();
  50. SqlCommand cmd = new SqlCommand("SELECT * FROM Table_1",conn);
  51. SqlDataReader dr = cmd.ExecuteReader();
  52. dr.Read();
  53. byte[] image = (byte[])dr["photo"];
  54. conn.Close();
  55. if (image.Length == 0)
  56. return;
  57. string photoUrl = Environment.CurrentDirectory + "\\1.jpg";
  58. FileStream fs = new FileStream(photoUrl, FileMode.OpenOrCreate, FileAccess.Write);
  59. BinaryWriter bw = new BinaryWriter(fs);
  60. bw.BaseStream.Write(image, 0, image.Length);
  61. bw.Flush();
  62. bw.Close();
  63. picbox_image.ImageLocation = photoUrl;
  64. }
  65. }
  66. }

效果如图:

完整项目(包含数据库文件)下载地址:http://download.csdn.net/source/3576866

C#操作SQL Server中的Image类型数据的更多相关文章

  1. delphi 转换sql server 中的 bit类型

    FieldByName('e').AsBoolean = false 其中e为 sql server 中的bit类型.

  2. 快速查看SQL Server 中各表的数据量以及占用空间大小

    快速查看SQL Server 中各表的数据量以及占用空间大小. CREATE TABLE #T (NAME nvarchar(100),ROWS char(20),reserved varchar(1 ...

  3. 浅析SQL Server 中的SOS_SCHEDULER_YIELD类型的等待

    本文出处:http://www.cnblogs.com/wy123/p/6856802.html 进程的状态转换 在说明SOS_SCHEDULER_YIELD等待之前,先简要介绍一下进程的状态(迷迷糊 ...

  4. SQL Server中时间段查询和数据类型转换

    不知道什么时候对数据独有情种,也许是因为所学专业的缘故,也许是在多年的工作中的亲身经历,无数据,很多事情干不了,数据精度不够,也很多事情干不了,有一次跟一个朋友开玩笑说,如果在写论文的时候,能有一份独 ...

  5. 【SQL Server数据迁移】64位的机器:SQL Server中查询ORACLE的数据

    从SQL Server中查询ORACLE中的数据,可以在SQL Server中创建到ORACLE的链接服务器来实现的,但是根据32位 .64位的机器和软件, 需要用不同的驱动程序来实现. 在64位的机 ...

  6. 【SQL Server数据迁移】32位的机器:SQL Server中查询ORACLE的数据

    从SQL Server中查询ORACLE中的数据,可以在SQL Server中创建到ORACLE的链接服务器来实现的,但是根据32位 .64位的机器和软件,需要用不同的驱动程序来实现. 在32位的机器 ...

  7. 将SQL SERVER中查询到的数据导成一个Excel文件

    -- ====================================================== T-SQL代码: EXEC master..xp_cmdshell 'bcp 库名. ...

  8. 向SQL Server中导入Excel的数据

    1.  手动界面导入Excel数据 同 https://jingyan.baidu.com/article/ce09321b9a0e252bff858ff9.html 首先打开并登陆sql serve ...

  9. SQL Server中的uniqueidentifier类型

    uniqueidentifier类型可以配合T-SQL中的newid和newsequentialid来生成唯一标识符,具体区别如下(摘抄自微软官方文档). Nonsequential GUIDs: Y ...

随机推荐

  1. Java过滤特殊字符

    Java正则表达式过滤 1.Java过滤特殊字符的正则表达式----转载 java过滤特殊字符的正则表达式[转载] 2010-08-05 11:06 Java过滤特殊字符的正则表达式   关键字: j ...

  2. ASP.NET MVC 相关的社群与讨论区

    ASP.NET MVC 官方论坛  http://forums.asp.net/1146.aspx 台湾微软MSDN论坛 --- ASP.NET 与 AJAX(ASP.NET AND AJAX)讨论区 ...

  3. 转载 -- 基于原生JS与OC方法互相调用并传值(附HTML代码)

    最近项目里面有有个商品活动界面,要与web端传值,将用户在网页点击的商品id 传给客户端,也就是js交互,其实再说明白一点就是方法的互相调用而已. 本文叙述下如何进行原生的JavaScript交互 本 ...

  4. 该 Bucket 已存在,或被其他用户占用

  5. mongo 数据库提前关闭 避免读写任务没有结束,异步任务没有完成,同步指令提前关闭数据库:'MongoError: server instance pool was destroyed'

    mongo 数据库提前关闭 // mongodb - npm https://www.npmjs.com/package/mongodb const mongoCfg = { uri: 'mongod ...

  6. 对A轮的追逐变得越加狂热,当前距离互联网泡沫到底有多近?

    编者注:本文来自TOMASZ TUNGUZ,中文版由天地会珠海分舵进行编译. 依据NVCA披露的最新数据,在2015年第二季度.VC总共进行了167亿美元的投资,大约是2000年互联网泡沫时候同期的6 ...

  7. 移动App该怎样保存用户password

    版权声明:本文为横云断岭原创文章,未经博主同意不得转载.微信公众号:横云断岭的专栏 https://blog.csdn.net/hengyunabc/article/details/34623957 ...

  8. java中的clone方法

    Java中对象的创建 clone顾名思义就是复制, 在Java语言中, clone方法被对象调用,所以会复制对象.所谓的复制对象,首先要分配一个和源对象同样大小的空间,在这个空间中创建一个新的对象.那 ...

  9. ZOJ - 1504 Slots of Fun 【数学】

    题目链接 http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=1504 题意 给出一串字符串 里面的每个字符的位置 都按照题目的意 ...

  10. zabbix 监控 haproxy 记录

    1. 当配置好后,遇到 Value should be a JSON object. 该如何是好? sudo 文件增加: zabbix ALL=(ALL) NOPASSWD: ALL haproxy ...