• 软件测试技术
  • 软件测试博客
  • 软件测试视频
  • 开源软件测试技术
  • 软件测试论坛
  • 软件测试沙龙
  • 软件测试资料下载
  • 软件测试杂志
  • 软件测试人才招聘
    暂时没有公告

字号: | 推荐给好友 上一篇 | 下一篇

Hibernate的特点思考

发布: 2008-4-28 10:59 | 作者: 不详 | 来源: www.matrix.org.cn | 查看: 139次 | 进入软件测试论坛讨论

领测软件测试网

当然类要事先写好,这里就不详细写了。

保存问题更严重,取出来用sql映射已经可以很好地解决了,基本上一个函数、一群SQL,加上少少的XML就可以表达清楚了,但是这不能解决保存对象的问题。

假想中的保存API。

public void saveObject(Connection conn, Object obj,String xml);  //保存单个对象,简单地将对象扩展成sql,允许xml映射,也可以不映射

public void saveObjects(Connection conn, List objs, String xml);  //将对象树保存到数据库

上一篇取出的List或人工组合的List可以用saveObjects来保存,这个函数的任务就比较重了,因为没有状态,所以要判断修改过非常麻烦。

一种思路是在对象是增加属性,然后由开发者维护,比如界面上是否修改很有可能是有状态位的,这个状态位就可以用起来,然后函数根据这个状态位来判断是否去更新。

一种思路是从Class本身中就得知对象是否被改过,类似AOP,在修改的时候记录一下,然后函数来判断是否改过,然后组成SQL来更新。

至于批量修改是强项,直接用SQL即可,学习SQL比HQL的成本要低,毕竟这么多年了。

外围实用函数的思考:基本上都针对SQL的生成,或数据库函数的替换

public String generateInsertSQL(DBType type,Object obj);//生成insert语句

public String generateUpdateSQL(DBType type,Object obj);//生成update语句

public String generateSelectSQL(DBType type,Object obj);//生成select语句

延伸阅读

文章来源于领测软件测试网 https://www.ltesting.net/

54/5<12345>

关于领测软件测试网 | 领测软件测试网合作伙伴 | 广告服务 | 投稿指南 | 联系我们 | 网站地图 | 友情链接
版权所有(C) 2003-2010 TestAge(领测软件测试网)|领测国际科技(北京)有限公司|软件测试工程师培训网 All Rights Reserved
北京市海淀区中关村南大街9号北京理工科技大厦1402室 京ICP备10010545号-5
技术支持和业务联系:info@testage.com.cn 电话:010-51297073

软件测试 | 领测国际ISTQBISTQB官网TMMiTMMi认证国际软件测试工程师认证领测软件测试网