当前位置:   article > 正文

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

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

一 存储到数据库

1、建立数据表UserPhoto

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

 photo为image


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

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

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

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

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Data;
  4. using System.Data.SqlClient;
  5. using System.Drawing;
  6. using System.Drawing.Imaging;
  7. using System.IO;
  8. using System.Linq;
  9. using System.Text;
  10. using System.Threading.Tasks;
  11. namespace importImage
  12. {
  13. class Class1
  14. {
  15. private SqlConnection ConnectionOpen()
  16. {
  17. string connectionString = "Server = 192.168.31.214; Database =Attendance; User ID = sa ; Password = dengrui2018;";
  18. SqlConnection conn = new SqlConnection(connectionString);
  19. conn.Open();
  20. return conn;
  21. }
  22. public static byte[] ImageToBytes(Image image)
  23. {
  24. if (image == null)
  25. {
  26. return null;
  27. }
  28. ImageFormat format = image.RawFormat;
  29. using (MemoryStream ms = new MemoryStream())
  30. {
  31. if (format.Equals(ImageFormat.Jpeg))
  32. {
  33. image.Save(ms, ImageFormat.Jpeg);
  34. }
  35. else if (format.Equals(ImageFormat.Png))
  36. {
  37. image.Save(ms, ImageFormat.Png);
  38. }
  39. else if (format.Equals(ImageFormat.Bmp))
  40. {
  41. image.Save(ms, ImageFormat.Bmp);
  42. }
  43. else if (format.Equals(ImageFormat.Gif))
  44. {
  45. image.Save(ms, ImageFormat.Gif);
  46. }
  47. else if (format.Equals(ImageFormat.Icon))
  48. {
  49. image.Save(ms, ImageFormat.Icon);
  50. }
  51. byte[] buffer = new byte[ms.Length];
  52. //Image.Save()会改变MemoryStream的Position,需要重新Seek到Begin
  53. ms.Seek(0, SeekOrigin.Begin);
  54. ms.Read(buffer, 0, buffer.Length);
  55. return buffer;
  56. }
  57. }
  58. public bool InsertPerImage(string rowAutoID, Image perImage)
  59. {
  60. SqlConnection conn = ConnectionOpen();
  61. int i = 0;
  62. if (perImage == null)
  63. {
  64. SqlCommand com = new SqlCommand("insert into UserPhoto(UserID) values('100020')", conn);
  65. com.Parameters.Add("UserID", SqlDbType.VarChar);//数据库里userID是varchar,这里转换为varchar
  66. com.Parameters["UserID"].Value = rowAutoID;
  67. i = com.ExecuteNonQuery();
  68. }
  69. else
  70. {
  71. SqlCommand com = new SqlCommand("insert into UserPhoto(UserID,photo) values(@UserID,@photo)", conn);
  72. com.Parameters.Add("UserID", SqlDbType.VarChar);
  73. com.Parameters["UserID"].Value = rowAutoID;
  74. com.Parameters.Add("photo", SqlDbType.Image);
  75. com.Parameters["photo"].Value = ImageToBytes(perImage);//调用方法将图片转换为二进制
  76. i = com.ExecuteNonQuery();//返回受影响的函数
  77. }
  78. if (i > 0)
  79. {
  80. conn.Close();
  81. return true;
  82. }
  83. else
  84. {
  85. conn.Close();
  86. return false;
  87. }
  88. }
  89. }
  90. }

3、调用方法

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

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

有空完善.....

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/知新_RL/article/detail/125272
推荐阅读
相关标签
  

闽ICP备14008679号