开发者社区> 路过秋天> 正文

MySql Blob图片类型存储Bug解决:索引超出了数组界限错误

简介:
+关注继续查看

告别了一周多的网络,终于回归,突见群里,有网友提了以下问题:


CYQ.Data框架测试:mysql数据库测试(保存blob类型的数据会出问题) ,针对mysql数据库做测试:发现更新blog字段,总是保存System.Byte[]

 

既然网友提出了问题,本地再试验一下:

先在本地装了个Mysql,又装了个navicat管理工具,又新建了个工程来测试:
简单的测试方法,就是放一个按钮,点击一下,读取远程图片,然后存到数据库,再读取出来显示到界面上。
管理工具随意建了个表“D1”,弄了三个id,img,name三个字段。


示例代码如下,因为测试,代码就没写的太规范:

复制代码
protected void btnTest_Click(object sender, EventArgs e)
    {
        string url = "http://www.baidu.com/img/baidu_jgylogo3.gif";
        bool result = false;
        int id = 0;
       string conn = "host=127.0.0.1;Port=3306;Database=test;uid=root;pwd=123456";
       //  string conn = "server=.;database=demo;uid=sa;pwd=123456";
        using (MAction action = new MAction("d1", conn))
        {
            WebClient wc = new WebClient();
            try
            {
                //if (action.Fill(2))
                
//{
                    byte[] data = wc.DownloadData(url);
                    action.Set("img", data);
                    action.Set("name""ldf");
                    result = action.Insert(InsertOp.ID);
                    id = action.Get<int>("id");
                //}
            }
            catch (Exception err)
            {
                Log.WriteLogToTxt(err);
            }
        }
        if (result)//再开一个读取试试
        {
            using (MAction action = new MAction("d1", conn))
            {
                if (action.Fill(id))
                {
                    Response.BinaryWrite(action.Get<byte[]>("img"));
                }
            }
        }
}
复制代码

 

解决与调试经过:

经本地测试,调试,发现对blob类型的参数赋值时,抛出异常:索引超出了数组界限。
异常太迷惑,网上搜了一下,有人说是:Mysql.dll的版本问题,花了一个csdn积分下了一个6.2.3版本,还是不顶用。 
然后无意识的进行调试,估计运气问题,竟然让我发现了问题所在,只能说是运气好。


看一段小代码,对参数的赋值,参数多数据库支持时,类似这种写法:

复制代码
 DbParameter para = _fac.CreateParameter();//通过工厂广告获得当前数据库类型的参数
            para.ParameterName = parameterName;
            para.Value = value == null ? DBNull.Value : value;
            para.DbType = dbType;

            if (size > -1)//设定长度。
            {
               para.Size = size;
            }
            para.Direction = direction;
复制代码
 

这代码其实很简单:

产生了一个参数,然后赋参数名,参数值,参数类型,参数大小和参数指向。
而Mysql竟然在对参数Size赋值的问题处理上有些Bug。


当我调试跳过对para.Size赋值时,竟然正常了。

于是代码改成了这样:

if (dbType != DbType.Binary && size > -1)//mysql不能设定长度,否则会报索引超出了数组界限错误。


然后我测试了下其它数据库,发现指定size是正常的,最后得出一结论:

经过测试,其它数据库类型对Size的赋值是正常的,唯Mysql有问题,为此,在编写进行多数据库支持的框架时,总会时不时的遇到好多问题,别纠结,始终要解决。

 


版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
Xcode 升级后,常常遇到的遇到的警告、错误,解决方法(转)
从sdk3.2.5升级到sdk 7.1中间废弃了很多的方法,还有一些逻辑关系更加严谨了。1,警告:“xoxoxoxo”  is deprecated解决办法:查看xoxoxoxo的这个方法的文档,替换掉这个方法即可。
1110 0
duilib relativepos属性导致控件错误的bug修复
转载请说明出处,谢谢~~         我在仿酷狗音乐播放器的开发日志系列里,曾经提到了这个bug,文章地址为:http://blog.csdn.net/zhuhongshu/article/details/38145365。
965 0
SSH 文件上传错误:encountered 1 errors during the transfer终极解决方法:
以下方法简单排序,从简单到复杂: 法一:在SSH Secure File Transfer(上传文件那个),打开“Operation”菜单,打开“File Transfer Mode”子菜单,再选择“Binary”,OK! 法二:把服务器上同名文件删掉再传 法三:如果文件在桌面上,将要上传的文件复制到其它分区,再上传! 法四:到 http://winscp.
852 0
duilib 修复padding属性导致其他控件自动计算宽高度错误的bug和导致自己宽高度错误的bug
转载请说明原出处,谢谢~~:http://blog.csdn.net/zhuhongshu/article/details/42950733          BUG 一:padding导致其他控件宽度计算错误             今天在写项目的一个布局时,用到了最常用的相对布局属性padding:在一个纵向容器里,给其中的各个子元素设置了padding属性来做相对布局。
1139 0
+关注
174
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
JS零基础入门教程(上册)
立即下载
性能优化方法论
立即下载
手把手学习日志服务SLS,云启实验室实战指南
立即下载