告别了一周多的网络,终于回归,突见群里,有网友提了以下问题:
CYQ.Data框架测试:mysql数据库测试(保存blob类型的数据会出问题) ,针对mysql数据库做测试:发现更新blog字段,总是保存System.Byte[]
既然网友提出了问题,本地再试验一下:
先在本地装了个Mysql,又装了个navicat管理工具,又新建了个工程来测试:
简单的测试方法,就是放一个按钮,点击一下,读取远程图片,然后存到数据库,再读取出来显示到界面上。
管理工具随意建了个表“D1”,弄了三个id,img,name三个字段。
简单的测试方法,就是放一个按钮,点击一下,读取远程图片,然后存到数据库,再读取出来显示到界面上。
管理工具随意建了个表“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"));
}
}
}
}
{
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版本,还是不顶用。
然后无意识的进行调试,估计运气问题,竟然让我发现了问题所在,只能说是运气好。
异常太迷惑,网上搜了一下,有人说是: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。
而Mysql竟然在对参数Size赋值的问题处理上有些Bug。
当我调试跳过对para.Size赋值时,竟然正常了。
于是代码改成了这样:
if (dbType != DbType.Binary && size > -1)//mysql不能设定长度,否则会报索引超出了数组界限错误。
然后我测试了下其它数据库,发现指定size是正常的,最后得出一结论:
经过测试,其它数据库类型对Size的赋值是正常的,唯Mysql有问题,为此,在编写进行多数据库支持的框架时,总会时不时的遇到好多问题,别纠结,始终要解决。
版权声明:本文原创发表于 博客园,作者为 路过秋天 本文欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则视为侵权。 |
个人微信公众号![]() |
Donation(扫码支持作者):支付宝:![]() |
Donation(扫码支持作者):微信:![]() |
![]() |
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· CSnakes vs Python.NET:高效嵌入与灵活互通的跨语言方案对比
· DeepSeek “源神”启动!「GitHub 热点速览」
· 我与微信审核的“相爱相杀”看个人小程序副业
· Plotly.NET 一个为 .NET 打造的强大开源交互式图表库
· 上周热点回顾(2.17-2.23)