加入收藏 | 设为首页 | 会员中心 | 我要投稿 甘南站长网 (https://www.0941zz.com/)- 科技、行业物联网、开发、云计算、云管理!
当前位置: 首页 > 数据库 > MySql > 正文

c# – MySQL BLOB图像数据逐渐丢失?

发布时间:2020-12-15 06:24:20 所属栏目:MySql 来源:互联网
导读:在mysql中,MyISAM类型表有一个Image类型为mediumblob并存储捕获的图像.我得到了一些有趣且有问题的图像.一些图像逐渐丢失数据.Field type -------------------------- image mediumblob my.ini max allowd packet size se

在mysql中,MyISAM类型表有一个Image类型为mediumblob并存储捕获的图像.我得到了一些有趣且有问题的图像.一些图像逐渐丢失数据.

Field          type  
--------------------------
image         mediumblob

my.ini max allowd packet size set max_allowed_packet = 8M

这就是问题

当C#应用程序每次从服务器获取数据时,这些图像逐渐丢失数据并随机大小.我在100000个图像数据中得到了10-12个这样的坏图像.

这种行为可能是什么原因?任何人都有任何想法/解决方案如何解决/避免这个问题.

更新1:
从PictureBox读取字节

MemoryStream ms = new MemoryStream();
byte[] ret = null;

try
{
     picturebox.Image.Save(ms,System.Drawing.Imaging.ImageFormat.Jpeg);
     byte[] Data = new byte[ms.Length];
     ms.Read(Data,(int)ms.Length);
     ret = byteData;
     ms.Close();
 }         

将bytes数组保存为数据库作为中等blob数据.从数据库中检索数据时,我正在转换读取器数据

byte[] Data = (byte[])reader["Image"];
最佳答案 罪魁祸首是MyISAM存储类型.

我们使用InnoDB存储来存储一百万个图像并进行压力测试,我们得到了正确的结果.由于InnoDB符合酸性,因此无法正确检索文件或完全没有检索到文件(小于0.01%).

当我们转移到MyISAM时,故障率增加到20%,有损数据和您的情况一样.原因是,MyISAM使用表锁,因此当写入正在进行时,整个表被锁定,并且在超时的情况下,它会覆盖导致数据丢失的事情.

我们现在已经将所有内容都转移到了MS SQL,因为InnoDB运行良好,但它仍然没有重复使用已删除的文件空间,因此InnoDB不断增长. MS SQL express限制为10gb,因此我们创建了4-8gb的页面,并在那里存储blob.我们有自己的自定义复制,通过网络使用相同的配置在三台服务器上复制文件.

由于许多原因,将文件存储在磁盘上是不好的,每个人都在说文件系统是为高性能设计的,并且可以存储数百万个文件,但事实并非如此,当你有超过10万个文件时,驱动器无法更快地执行.它们在一个大文件和1000个较小文件中表现良好.目前我们存储了1000万个文件并将其存储在db中更有意义,因为db对查询进行了优化并且执行了良好的缓存.您可以在http://akashkava.com/blog/127/huge-file-storage-in-database-instead-of-file-system/阅读更多内容

这就是MongoDb,Hadoop,Azure Blob Store,Haystack和Amazon S3发明的确切原因.

(编辑:甘南站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读