Cómo almacenar imágenes en la base de datos SQL y leer imágenes de la base de datos (solución)

 
Tabla de contenido

1. Seleccione una imagen local y guárdela en la base de datos

2.Método Save ()

3. Leer fotos de la base de datos


Recientemente, el proyecto necesita cargar y descargar imágenes. Pensé en cómo almacenar imágenes. Puedes almacenarlas en la base de datos usando rutas locales y datos binarios. Finalmente, sopesamos los pros y los contras y decidimos almacenar las imágenes en la base de datos. Este artículo explica en detalle cómo almacenar imágenes en la base de datos SQL y cómo leer imágenes de la base de datos SQL. ¡Espero que puedas ganar algo! ! !

1. Seleccione una imagen local y guárdela en la base de datos

/// <summary>
/// 将图片存进数据库
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void button2_Click(object sender, EventArgs e)
{
      //点击按钮弹出对话框
      //选中图片,为Img的属性
      OpenFileDialog ofd = new OpenFileDialog();  //打开文件
      ofd.Title = "请选择图片文件";//弹出框的标题
      ofd.InitialDirectory = System.Environment.GetFolderPath(Environment.SpecialFolder.MyPictures);//设置系统目录
      // ofd.InitialDirectory = @"C:\Users\Administrator\Pictures";//设置系统目录
      ofd.Filter = "(*.jpg)|*.jpg";

      if (ofd.ShowDialog() == System.Windows.Forms.DialogResult.OK)
      {
          this.pictureBox1.Image = Image.FromStream(ofd.OpenFile());  //获取当前选择的图片
          string path = ofd.FileName.ToString(); //获取当前图片的路径
          FileStream fs = new FileStream(path, FileMode.Open, FileAccess.Read); //将指定路径的图片添加到FileStream类中
          BinaryReader br = new BinaryReader(fs);//通过FileStream对象实例化BinaryReader对象

          byte[] imgBytesIn = br.ReadBytes(Convert.ToInt32(fs.Length));//将图片转为二进制数据
          Save(imgBytesIn);//调用(自己写的一个方法)

       }

}

2.Método Save ()

/// <summary>
/// 存进数据库
/// </summary>
/// <param name="imgBytesIn">二进制数据</param>
private void Save(byte[] imgBytesIn)
{
     try
    {   //连接数据库
         SqlConnection con = new SqlConnection("server=192.168.111.100;uid=sa;pwd=123456;database=Chargetest");//连接本地数据库
          con.Open();

          SqlCommand cmd = new SqlCommand("insert into image (Img_url) values(@Image);", con); //SQL语句
          cmd.Parameters.Add("@Image", SqlDbType.Image);
          cmd.Parameters["@Image"].Value = imgBytesIn;
          cmd.ExecuteNonQuery();

          con.Close();
          MessageBox.Show("图片上传成功");

    }
    catch
    {
         MessageBox.Show("您选择的图片不能被读取或文件类型不对!", "错误", MessageBoxButtons.OK, MessageBoxIcon.Warning);

         }

   }

3. Leer fotos de la base de datos

/// <summary>
/// 从数据库读取图片
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void button1_Click(object sender, EventArgs e)
{
       byte[] MyData = new byte[0];
       using (SqlConnection conn = new SqlConnection("server=ZYB;Database =Chargetest; User ID = sa;Password =123456"))
      {
           conn.Open();
           SqlCommand cmd = new SqlCommand();
           cmd.Connection = conn;
           cmd.CommandText = "select * from image where Id=14"; //写自己要查图片的主键
           SqlDataReader sdr = cmd.ExecuteReader();
           sdr.Read();
           object o = sdr["img_url"];
           MyData = (byte[])sdr["img_url"];//读取第一个图片的位流
           MemoryStream memoryStream = null;
           memoryStream = new MemoryStream(MyData);
           pictureBox1.Image = Image.FromStream(memoryStream);//将图片赋给pictureBox1控件
           MessageBox.Show("读取成功");
              
       }
}

Si este blog es útil para usted, recuerde dejar un mensaje + me gusta.

Supongo que te gusta

Origin blog.csdn.net/promsing/article/details/109493991
Recomendado
Clasificación