百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>数据库> mysql怎样贮存读取图片
分享文章到:

mysql怎样贮存读取图片

发布时间:12/01 来源:未知 浏览: 关键词:
mysql贮存读取图片的办法:第一将图片转换成缓冲流;然后获得图片的字节数组并施行相干操纵;最后通过“publicvoidMapSearchQuery(outbyte[]imageByteResulet){...}”读取图片即可。

mysql贮存读取图片的办法:第一将图片转换成缓冲流;然后获得图片的字节数组并施行相干操纵;最后通过“public void MapSearchQuery(out byte[] imageByteResulet){...}”读取图片即可。

举荐:《mysql视频教程》

第一,介绍一下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映照,返回文件流(这个当前没试过,有工夫试过后再把经验分享给大家)。

以上就是mysql怎样贮存读取图片的细致内容,更多请关注 百分百源码网 其它相干文章!

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有150人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板