SQLserver C#将图片以二进制方式存储到数据库,再从数据库读出图片

65 篇文章 7 订阅

一 存储到数据库

1、建立数据表UserPhoto

 userID为varchar(50)    设置为标识列unique不能重复   alter table UserPhoto add  unique(UserID)

 photo为image


2、写一个类,主要有三个方法

(1)连接数据库的类ConnectionOpen()

(2)判断图片类型转换byte[]数组ImageToBytes(Image image)

(3)操作数据库将转换的二进制写进数据库

using System;
using System.Collections.Generic;
using System.Data;
using System.Data.SqlClient;
using System.Drawing;
using System.Drawing.Imaging;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace importImage
{
    class Class1
    {

        private SqlConnection ConnectionOpen()
        {
            string connectionString = "Server = 192.168.31.214; Database =Attendance; User ID = sa ; Password = dengrui2018;";
            SqlConnection conn = new SqlConnection(connectionString);
            conn.Open();
            return conn;
        }

        public static byte[] ImageToBytes(Image image)
        {
            if (image == null)
            {
                return null;
            }
            ImageFormat format = image.RawFormat;
            using (MemoryStream ms = new MemoryStream())
            {
                if (format.Equals(ImageFormat.Jpeg))
                {
                    image.Save(ms, ImageFormat.Jpeg);
                }
                else if (format.Equals(ImageFormat.Png))
                {
                    image.Save(ms, ImageFormat.Png);
                }
                else if (format.Equals(ImageFormat.Bmp))
                {
                    image.Save(ms, ImageFormat.Bmp);
                }
                else if (format.Equals(ImageFormat.Gif))
                {
                    image.Save(ms, ImageFormat.Gif);
                }
                else if (format.Equals(ImageFormat.Icon))
                {
                    image.Save(ms, ImageFormat.Icon);
                }
                byte[] buffer = new byte[ms.Length];
                //Image.Save()会改变MemoryStream的Position,需要重新Seek到Begin
                ms.Seek(0, SeekOrigin.Begin);
                ms.Read(buffer, 0, buffer.Length);
                return buffer;
            }
        }
        public bool InsertPerImage(string rowAutoID, Image perImage)
        {
            SqlConnection conn = ConnectionOpen();

            int i = 0;
            if (perImage == null)
            {
                SqlCommand com = new SqlCommand("insert into UserPhoto(UserID) values('100020')", conn);
                com.Parameters.Add("UserID", SqlDbType.VarChar);//数据库里userID是varchar,这里转换为varchar
                com.Parameters["UserID"].Value = rowAutoID;
                i = com.ExecuteNonQuery();
            }
            else
            {
                SqlCommand com = new SqlCommand("insert into UserPhoto(UserID,photo) values(@UserID,@photo)", conn);
                com.Parameters.Add("UserID", SqlDbType.VarChar);
                com.Parameters["UserID"].Value = rowAutoID;

                com.Parameters.Add("photo", SqlDbType.Image);
                com.Parameters["photo"].Value = ImageToBytes(perImage);//调用方法将图片转换为二进制
                i = com.ExecuteNonQuery();//返回受影响的函数
            }
            if (i > 0)
            {
                conn.Close();
                return true;
            }
            else
            {
                conn.Close();
                return false;
            }
        }
    }
}

3、调用方法

private void button5_Click(object sender, EventArgs e)
        {
            Class1 c1 = new Class1();
            string id = "10002";
             //调用方法  传递两个参数  编号,图片的路径
            bool aa = c1.InsertPerImage(id, Image.FromFile(@"E:\ssdVS\项目\importImage\importImage\image\bananer.jpg"));
            MessageBox.Show(aa.ToString());   //如果返回为true 则添加成功
        }

二 从数据库获取二进制转换为图片

有空完善.....

  • 1
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

香煎三文鱼

你的鼓励将是我创作的最大动力!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值