SQL Server 存储图片

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

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

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"); 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值