mysql存读图片_mysql如何储存读取图片

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

a8abf6ffc00c771622711c7c240803eb.png

首先,介绍一下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";

try

{

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;

try

{

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

try

{

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;

try

{

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映射,返回文件流(这个目前没试过,有时间试过后再把经验分享给大家)。

  • 0
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL数据库中存放图片有两种常见的方法。第一种方法是将图片保存的路径存储到数据库中。这意味着在数据库中创建一个字段来存储图片的路径,而实际的图片文件则保存在服务器的文件系统中。通过在数据库中存储图片路径,可以轻松地在应用程序中引用和显示图片。第二种方法是将图片以二进制数据流的形式直接写入数据库字段中。这意味着在数据库中创建一个字段来存储图片的二进制数据,而不是保存图片的路径。通过将图片以二进制数据流的形式存储在数据库中,可以更方便地管理和备份图片数据。选择哪种方法取决于具体的应用需求和性能考虑。\[1\] #### 引用[.reference_title] - *1* [mysql存储图片](https://blog.csdn.net/weixin_53370274/article/details/121942385)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [MySQL如何存储图片](https://blog.csdn.net/WYL2724/article/details/7558912)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值