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:直接返回一个对象