博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SQL Server 存储图片
阅读量:6272 次
发布时间:2019-06-22

本文共 1502 字,大约阅读时间需要 5 分钟。

// --------------------------上传图片并保存至数据库--------------------------------------

// 从本地文件中读取图片

System.IO.FileStream fs = new System.IO.FileStream(picPath, System.IO.FileMode.Open, System.IO.FileAccess.Read);

// 创建buff存储二进制数据

byte[] buffbyt = new byte[fs.Length];

fs.Read(buffbyt, 0, (int)fs.Length);

// 关闭文件流

fs.Close();

fs = null;

// 创建写入数据库的SQL 语句 用占位符代表图片变量

string comm = "insert into trafficsign (codeId ,picture) values ('" + dtInfo.Rows[0].Cells[0].Value.ToString() +"',@img,');";

SqlCommand cmd = new SqlCommand();

cmd.CommandType = System.Data.CommandType.Text;

cmd.CommandText = comm;

cmd.Connection = conn;

// SQL 语句的参数的数据类型是Image 和创建数据库要保持一致

cmd.Parameters.Add("@img", System.Data.SqlDbType.Image);

cmd.Parameters[0].Value = buffbyt;

// 执行SQL语句

cmd.ExecuteNonQuery();

buffbyt = null;

MessageBox.Show("上传成功!");

 

// ---------------------------------下载图片显示并存储-------------------------------------

 

string sql = "select codeId as 标识编码,picture from trafficsign where id = " + id;

SqlDataAdapter adapter = new SqlDataAdapter(sql,conn);

 

DataSet testDataSet = new DataSet();

// 创建DataSet,用于存储数据

adapter.Fill(testDataSet, "result_data");

InfoRow = testDataSet.Tables["result_data"].Rows[0];

byte[] buffByte = null;

buffByte = (byte[])InfoRow["picture"];

// 创建内存的流数据

System.IO.MemoryStream ms = new System.IO.MemoryStream(buffByte);

// 将文件流转换成图片数据

System.Drawing.Bitmap bmp = new Bitmap(ms);

// 将内存中的图片数据设定为picture box 的数据源

picBOX.Image = bmp;

// 将内存中的图片数据存储至硬盘上

bmp.Save(currPath + "//images// aaa.jpg"); 

 

转载地址:http://roopa.baihongyu.com/

你可能感兴趣的文章
《从零开始学Swift》学习笔记(Day 51)——扩展构造函数
查看>>
python多线程队列安全
查看>>
[汇编语言学习笔记][第四章第一个程序的编写]
查看>>
android 打开各种文件(setDataAndType)转:
查看>>
补交:最最原始的第一次作业(当时没有选上课,所以不知道)
查看>>
Vue实例初始化的选项配置对象详解
查看>>
PLM产品技术的发展趋势 来源:e-works 作者:清软英泰 党伟升 罗先海 耿坤瑛
查看>>
vue part3.3 小案例ajax (axios) 及页面异步显示
查看>>
软件测试(二)之 Failure, Error & Fault
查看>>
浅谈MVC3自定义分页
查看>>
.net中ashx文件有什么用?功能有那些,一般用在什么情况下?
查看>>
select、poll、epoll之间的区别总结[整理]【转】
查看>>
CSS基础知识(上)
查看>>
PHP中常见的面试题2(附答案)
查看>>
角色权限分配
查看>>
明小子动力上传拿webshell.zip
查看>>
ES6 Module export与import复合使用
查看>>
第三篇、image 设置圆角的几种方式
查看>>
关于Vs2010 C#使用DirectX的问题
查看>>
EPP(Eclipse PHP)语法高亮仿EditPlus配置
查看>>