JDBC、Ibatis、Hibernate对比、以及优点缺点(个人总结)

Ibatis优点
与JDBC比较:
1.减少了大约61%的代码量
2.简单,容易上手
3.架构级性能增强
4.sql语句与程序代码分离(便与修改)
5.简化项目中的分工
6.增强了移植性(数据库的可移植性)

缺点:
1.sql需要自己写(当然也有好处、比如某些SQL语句手动写的要比自动生存的性能要高)

2.参数只能带一个(解决方法配置ParameterMap)疑问:如果用JDK5.0新特性的可变参数呢来进行设计呢

 

Hibernate优点

1.对象关系数据库映射,抛弃了数据库中心的思想,完全面向对象的思想

2.透明持久化

3.事物

4.它没有浸入性,即所谓的轻量级框架

5.移植性很好

6.缓存机制,提供一级缓存、二级缓存

7.简洁的HQL编程

缺点

一、由于对持久层封装过于完整,导致DBA无法对SQL进行优化,效率降低;

二、Hiberante的映射文件的编写也显得比较繁琐,容易出错。

三、不能灵活使用原生SQL

四、对JDBC的封装导致与数据库交互效率明显降低。框架中大量使用反射机制也是运行效率变慢

五、N+1问题

六、Hibernate在批量处理数据的时候是弱势

 

 

JDBC、IBatis、Hibernate明显对比

jdbc更为灵活,更加有效率,系统运行速度快。但是用起来麻烦,有的时候用了存储过程就不方便数据库移植了。

Hibernate,IbatIS 关系数据库框架,开发速度快,更加面向对象,可以移植更换数据库,但影响系统性能。

 

三者对比

jdbc:手动
手动写sql
delete、insert、update要将对象的值一个一个取出传到sql中,不能直接传入一个对象。
select:返回的是一个resultset,要从ResultSet中一行一行、一个字段一个字段的取出,然后封装到一个对象中,不直接返回一个对象。
ibatis的特点:半自动化
sql要手动写
delete、insert、update:直接传入一个对象
select:直接返回一个对象
hibernate:全自动
不写sql,自动封装
delete、insert、update:直接传入一个对象
select:直接返回一个对象


以上是我个人总结的优缺点,如果有不正确之处或者需要补充希望高手指出!
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值