MyGeneration学习笔记(3) : dOOdads及生成代码的一些bug

简介:


      没有软件会不存在bug,找到一个bug只能说明系统还存在Bug。MyGeneration也不例外,其中存在存在bug;但我们不能因为其有bug而不去用它,这是因噎废食。下面就是我在使用dOOdad时遇到的几个bug及我自己的解决办法,发出来与大家共享,避免大家与我做重复的调试工作。

 

1.  连接字符串初始化
        在配置文件web.config或app.config配置连接字符串。dOOdad项目中默认的key是"dbConnection",也可以修改BusinessEntity类中的_defaultConfig字段的值来修改key的默认值。
        另外,dOOdad项目有个问题就是连接字符串并没有初始化(可能是模版的bug),这时需要手动初始化。解决方法参看我的本系列第一篇文章使用MyGeneration生成sp和代码中的part5。


2.  向数据库中插入一行:

      下面是dOOdad给定一份示例代码,执行这段代码会有点小问题:

Employees emps  =   new  Employees();
emps.AddNew();
emps.LastName 
=   " Smith " ;
emps.HireDate 
=  DataTime.Now;
emps.Save();
int  empsID  =  emps.EmplyeeID; // 插入后返回主键值。

         调用Save方法插入数据库没有问题,但是获取主键值会抛出异常。默认生成的代码没有将ID作为输出参数,所以Save后emps.EmplyeeID仍然为空,不能转换成int。更正方法是在dOOdad生成业务实体抽象类Employees的GetInsertCommand()方法中加一条语句:

CreateParameters(cmd);
cmd.Parameters[
" @ID " ].Direction  =  ParameterDirection.Output; // 要加入的语句
return  cmd;

         现在执行上面的示例代码就不会出现异常了。

 


3.   BusinessEntity中Setstring方法也存在问题

protected   void  Setstring( string  columnName,  string  data)
{
    
if(0 == data.Length) 
           _dataRow[columnName] 
= DBNull.Value;
    
else
           _dataRow[columnName] 
= data;
}

    显然,当为第二个参数data传入null时,会有问题。修正:if的判断条件改为:if ((null == data) || (0 == data.Length))但按照FxCop性能规则,这种判断字符串非空的方法不是很高效,推荐用String.IsNullOrEmpty(data)来判断是否为空。其他判读字符串非空的地方也存在同样的问题。

 


4. BusinessEntity类提供的ToXml()和FromXml()两个方法,实现了字符串到业务实体的转化。
         不过这种是由代价的:ToXml将业务实体换成string后,会丢失部分重要信息,如DataSet的Schema、DataRow的状态(Added/Modified/Deleted)、没有赋值的属性等,所以FromXml不能完全转换回原来的DataTable。
例如:

Employee emps  =   new  Employee();
emps.LoadByPrimaryKey(id)
string  s  =  emp.ToXml();
Employee temp 
=   new  Employee();
temp.LoadFromXml();

         执行上面的代码后,temp已经严重失真了。例如访问temp.ID就会抛出InvalidCastException异常,访问temp对象的其他非字符串属性也会抛出该异常。产生这个问题原因可能是经过ToXml和FromXml转换后,_dataRow[columnName]的数据类型信息丢失了,统一都成了string类型,强制类型转换会抛出异常。
         Getbool、Getint等一系列Get***方法(GetString除外)都存在这个问题,解决办法是用Convert类来转换,将强制类型转换换成Convert.To***()。

 

5.  更多的Bug,正等着大家去发现^_^


本文转自Silent Void博客园博客,原文链接:http://www.cnblogs.com/happyhippy/archive/2006/08/23/601239.html,如需转载请自行联系原作者

相关文章
|
10月前
|
缓存 算法 安全
程序员写代码为什么要阅读源码?
阅读一篇技术文章,畅聊一个技术话题。本期文章推荐的是《Node 中的 AsyncLocalStorage 的前世今生和未来》,一起来聊聊开发者阅读源码的这件事。阅读源码的过程实质上是对软件构建技术和架构深度的一种持续学习和理解。阅读源码可以揭示代码的内在逻辑,可以对技术深度的理解,也能提高对技术的理解程度。然而,仅仅阅读源码并不能代替实践操作,因为通过实践,可以更加全面的理解代码的深度和进展。
105 1
|
11月前
|
JavaScript 前端开发 API
每个 Bug 都值得认真对待:分享一个 debug 的案例,推荐给前端实习生参考
每个 Bug 都值得认真对待:分享一个 debug 的案例,推荐给前端实习生参考
215 0
|
11月前
|
Java 区块链 Maven
Spring源码下载与编译,Debug学习才有效率
Spring源码下载与编译,Debug学习才有效率
277 0
|
运维 架构师 Java
你目前写过最大的bug
你目前写过最大的bug
125 0
|
JavaScript 知识图谱
修改第三方插件或库的源码经验技巧总结
修改第三方插件或库的源码经验技巧总结
修改第三方插件或库的源码经验技巧总结
|
测试技术 Go 数据库
Go开发技巧和踩坑分享 | 代码结构 调试技巧 配置文件 元数据
分享一下最近使用GoFrame开发go项目的经验分享。
143 0
|
前端开发 计算机视觉 Python
代码报错还好说,源码报错才难搞!分享自己源码报错的解决过程!
代码报错还好说,源码报错才难搞!分享自己源码报错的解决过程!
93 0
代码报错还好说,源码报错才难搞!分享自己源码报错的解决过程!
saba开发笔记(一):saba介绍、编译使用以及测试
saba开发笔记(一):saba介绍、编译使用以及测试
saba开发笔记(一):saba介绍、编译使用以及测试
|
算法 Java 程序员
如何使用IDEA断点调试(debug), 用图文并茂的方式来教你
如何使用IDEA断点调试(debug), 用图文并茂的方式来教你
如何使用IDEA断点调试(debug), 用图文并茂的方式来教你