Hibernate专业知识介绍
创始人
2024-06-07 16:51:04
0

Hibernate有很多值得学习的地方,这里我们主要介绍Hibernate专业知识,包括介绍Hibernate/JPA的一些思想等方面。

大约一年以前,我为了学习一些Hibernate专业知识,因此我参加了一个Hibernate项目。从那时起,我一直在使用Hibernate框架下的JPA(Java持久API)实现,使用的思想仍就是一样的。那个项目使用了一个数据库,这个数据库规模有些大,略显落后,并且还被许多的应用程序共用。为了尽快加入到项目中,我开始学习一些Hibernate知识。从书本上的例子开始学习,感觉很简单,学起来也很快,但是发现从零开始开发一个项目,并且控制它又是另外一回事了。试着在一个大型,复杂,被许多应用程序共用的数据库上使用Hibernate就又完全不同了。弄清楚了我可能遭遇到的技术难点,我开始想别的招了,要尽快从另外的方向开始,克服困难。

在最终的学习和实践中,我发现我还是学到了许多重要的东西,虽然我们的项目还没有完全做完,但是我认为我们目前已经非常漂亮的应用了Hibernate/JPA的一些思想。现在我需要重新思考反省我所学到的东西,如下便是我学到的一些Hibernate专业知识:

1.让数据库做自己擅长的工作

我们想有一个好的,清晰的数据模型,因此我们不惜任何代价写一些额外的查询语句来获取对象相关数据,要么使用存储过程,要么使用函数。这是做法是错误的,数据库优势在于存储,而不是保持Hibernate创建或读写的数据。举个例子,我们有一个对象,与之相关联的有一个状态。这个状态在整个应用程序中都要用到,因此,它毫无疑问是要执行的,但是,我们不想每次都要单独的写一个查询语句。这个问题在于,这个状态是从一些统计计算中派生出来的,并且这些统计计算需要用到一对多的关系。每次从加载的对象中读取数据的代价是非常高的。后来跟我们其中的一位数据库管理员交流了一下,发现一个我们可以使用的sql函数能够很快的获得该状态。我们使用@Formula来映射成一个状态属性,就能得到我们所需要的所有东西。这仍就是域模型的一部分,但是执行起来非常好。有时像这样的一个折衷的办法能够起到很大的效果。

2.分解数据库

在一开始,我就想在Hibernate中模型化整个数据库。结果发现这是不切实际的,原因如下:
◆这是一项巨大的工程,并且要花费几周的时间,而用户根本看不到你做了什么实际的工作。
◆我不可能在第一次就把它弄好,后继的开发者无论如何都会修改它们的。

现在有一个趋势,就是希望在开始之前,将所有的事情都进行映射,但是,当时你开始这么做后,你不需在这上面花很多的时间。我后来发现一个好的办法,就是将数据库分解,工作的时候一块一块的进行,发现这很有帮助。

3.密切注意触发器

密切注意数据库触发器有如下两个原因:
◆在后台触发器很隐蔽的执行了一些功能,让你很是疑惑,不知道发生了什么。
◆当你在Hibernate端需要复制一些东西的时候,触发器会做一些手脚。之前我们好几次没有认识到这个教训,导致我们丢失了很多数据,这些都是由触发器引起的,这几乎让我们很是郁闷。以上总结我的一些Hibernate专业知识。

【编辑推荐】

  1. Hibernate可行性全面概括
  2. Hibernate Sequence基础描述
  3. 浅析Hibernate使用EhCache
  4. Hibernate的一级Cache
  5. Hibernate update浅谈

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...