mysql存储和读取图片_MySQL

php中文网
发布: 2016-06-01 13:08:36
原创
1340人浏览过

    首先,介绍一下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             {
                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[]的数据

EasySitePM Enterprise 企业网站管理系统3.5.10.0413 UTF8
EasySitePM Enterprise 企业网站管理系统3.5.10.0413 UTF8

EasySitePM Enterprise3.5系统是一款适用于不同类型企业使用的网站管理平于,它具有多语言、繁简从内核转换、SEO搜索优化、图片自定生成、用户自定界面、可视化订单管理系统、可视化邮件设置、模板管理、数据缓存+图片缓存+文件缓存三重提高访问速度、百万级数据快速读取测试、基于PHP+MYSQL系统开发,功能包括:产品管理、文章管理、订单处理、单页信息、会员管理、留言管理、论坛、模板管

EasySitePM Enterprise 企业网站管理系统3.5.10.0413 UTF8 0
查看详情 EasySitePM Enterprise 企业网站管理系统3.5.10.0413 UTF8

    //将图片字节数组加载入到缓冲流
                 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映射,返回文件流(这个目前没试过,有时间试过后再把经验分享给大家)。

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
热门推荐
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号