mysql数据库怎样储存读取图片

60次阅读
没有评论

共计 3262 个字符,预计需要花费 9 分钟才能阅读完成。

自动写代码机器人,免费开通

这篇文章主要介绍了 mysql 数据库怎样储存读取图片,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让丸趣 TV 小编带着大家一起了解一下。

mysql 储存读取图片的方法:首先将图片转换成缓冲流;然后获得图片的字节数组并执行相关操作;最后通过“public void MapSearchQuery(out byte[] imageByteResulet){…}”读取图片即可。

    首先,介绍一下 mysql 相关的数据类型:MySQL 中有四种 BLOB 类型,TinyBlob(最大 255Byte),Blob(最大 65K),MediunBlob(16M),LongBlob(最大 4G)。这里注意一下如果你数据库出现相关的 Data too long… 字样可能是你选择的种类的大小不够。

    接下来简单说一下我为什么没有用存储图片路径的方式,而采取了直接在 MySQL 中存储图片的方式。原因有两点:

   1、本身不需要大量图片,一个数据库只需要一张图片

   2、软件结构是要通过 WebService 由一个主客户端去访问下面附属的几个客户端,如果附属客户端不存储图片直接供主客户端访问,那么主客户端势必就需要一个加载图片的功能(类似于 FTP 的功能)。

    下面还是直接上代码吧:

public bool MapSearchWrite(string strImagePath)
 // 将图片转换成缓冲流
 FileStream fs = new FileStream(strImagePath, FileMode.Open, FileAccess.Read);
 // 获得图片的字节数组
 byte[] byImage = new byte[fs.Length];
 fs.Read(byImage, 0, byImage.Length);
 fs.Close();
 // 数据库连接
 MySqlConnection conn = new MySqlConnection();
 conn.ConnectionString = Server=localhost;Uid=root;Password=123456;Database=firefighting;charset=gb2312 
 conn.Open();
 catch
 conn.Close();
 conn.Dispose();
 throw new ArgumentException( 地图检索数据库连接失败 
 // 判断数据库内部有无记录
 string strQueryCmd = select PicNum from images 
 MySqlCommand cmdQuery = new MySqlCommand(strQueryCmd, conn);
 MySqlDataReader dataReader = cmdQuery.ExecuteReader();
 // 执行操作
 MySqlCommand cmd = new MySqlCommand();
 if (dataReader.Read())
 cmd.CommandText = update images set Image=@byImage 
 else
 cmd.CommandText = insert into images(Image) values(@byImage) 
 cmd.CommandType = CommandType.Text;
 cmd.Parameters.Add(@byImage , MySqlDbType.MediumBlob);
 cmd.Parameters[0].Value = byImage;
 cmd.Connection = conn;
 int affectedRows = 0;
 affectedRows = cmd.ExecuteNonQuery();
 catch
 affectedRows = -1;
 // 关闭连接等
 cmd.Dispose();
 conn.Close();
 conn.Dispose();
 if (affectedRows = 0)
 return false;
 else
 return true;
 }

    这是把图片插入到数据库的操作代码,路径的话就是你所需要存储的图片所在的路径(包括图片的名字和后缀名哦),另外我这里采用的是 ADO.NET 的连接方式,语言是 C# 的,其他代码也不用我解释了 ……

    下面是读取 MySQL 中的图片的代码

public void MapSearchQuery(out byte[] imageByteResulet)
 imageByteResulet = null;
 MySqlConnection conn = new MySqlConnection();
 conn.ConnectionString = Server=localhost;Uid=root;Password=123456;Database=firefighting;charset=gb2312 
 conn.Open();
 catch
 conn.Close();
 conn.Dispose();
 throw new ArgumentException( 地图检索数据库连接失败 
 string strQueryCmd = select Image from images limit 1 
 MySqlCommand cmd = new MySqlCommand(strQueryCmd, conn);
 MySqlDataReader dataReader = null;
 dataReader = cmd.ExecuteReader();
 catch
 dataReader.Dispose();
 cmd.Dispose();
 conn.Close();
 conn.Dispose();
 throw new ArgumentException( 地图检索查询地图失败 
 if (dataReader.Read())
 imageByteResulet = new byte[dataReader.GetBytes(0, 0, null, 0, int.MaxValue)];
 dataReader.GetBytes(0, 0, imageByteResulet, 0, imageByteResulet.Length);
 // 将图片字节数组加载入到缓冲流
 // MemoryStream imageStream = new MemoryStream(imageByte);
 // 从缓冲流生成图片
 //imageResulet = Image.FromStream(imageStream, true);
 dataReader.Dispose();
 cmd.Dispose();
 conn.Close();
 conn.Dispose();}

    当然这里我是照顾到 Image 对象不能通过 WebService 传输而把 BLOB 数据只转换成 byte[] 在传输,如果不需要这个功能的换可以直接把相关代码踢出来再将 byte[] 转成图片对象即可,一下提供两种方法

第一种:imageByte 是调用上面函数得到的 byte[] 的数据

// 将图片字节数组加载入到缓冲流 
MemoryStream imageStream = new MemoryStream(imageByte);
 // 从缓冲流生成图片 
 imageResulet = Image.FromStream(imageStream, true);
 //pictureBox 是一个显示图片或者视频的 C# 控件
 pictureBox.Image = imageResulet;

这样就把图片读取出来并显示出来了

第二种:BitMap 是 System.Drawingm 命名空间中的

Bitmap bm = new Bitmap(new MemoryStream(
imageByte

pictureBox1.Image = bm;

那么,到此我就说完了,当然不是迫不得已不要把图片存到数据库中,可以做个 url 映射,返回文件流。

感谢你能够认真阅读完这篇文章,希望丸趣 TV 小编分享 mysql 数据库怎样储存读取图片内容对大家有帮助,同时也希望大家多多支持丸趣 TV,关注丸趣 TV 行业资讯频道,遇到问题就找丸趣 TV,详细的解决方法等着你来学习!

向 AI 问一下细节

丸趣 TV 网 – 提供最优质的资源集合!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-12-18发表,共计3262字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)