JPA,感觉有点鸡肋

看了下JPA的介绍,就是在原有ORM的基础上抽象出一层通用接口,以便可以任意替换不同的ORM实现,有的朋友认为JPA的出现可以替代掉DAO,可是事实上,这确是大错特错了,我认为JPA非但不能替换掉DAO,而且因为DAO的存在而显得更加尴尬。

为什么?JPA虽然抽象了ORM的接口,想统一ORM标准,但是也正因为如此,它实际和直接使用ORM框架没有区别(除了能够任意替换不同实现以外),因为即使使用JPA,我们一样不能缺少DAO,我们来看看DAO的主要作用:
1、DAO将持久逻辑抽象出来,让业务层不需关注与持久相关的逻辑
2、在DAO层我们可以任意更换不同的持久实现,而无需更改业务层

从以上DAO两个主要作用看来,第一点,即使使用JPA也不能缺少,因为JPA并不能将持久相关逻辑抽象,对于第二点,JPA更换的是更底层即ORM框架的实现,而DAO是从持久逻辑处更换ORM实现,所以JPA比DAO来得容易,可是出于商业原因,JPA并无法全面的顾及到各个方面,不能够像单独的ORM那样提供灵活的功能,因此也失去了不少单独ORM框架的特色,而如果要使用这些被忽略的特性,则必须绕开JPA而使用。

站在我的观点上,我宁愿在更换实现时麻烦点(不算太麻烦吧,至少不用改动业务层),也不愿意放弃掉ORM特有的一些特性,因此我觉得JPA固然目标远大,但是实质上并不能带给我多大的好处,而且我想我也很少有机会更换ORM实现吧。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值