-
也用了这么久的Hibernate和MyBatis了,一直打算做一个总结,就他们之间的优缺点说说我自己的理解:
- 首先,Hibernate是一个ORM的持久层框架,它使用对象和我们的数据库建立关系,在Hibernate中,操作数据库实际上时通过对象状态的改变来改变数据中对应表的值,此时就是通过hql来操作数据库的,就不在通过sql来直接操作我们的数据库。
-
- 我认为,最能体现Hibernate的面向对象的方法来操作数据库的一点,就是:在新创建一个对象后,在调用Hibernate的save方法时,此时HIbernate并不会发送插入数据的sql,而是等到我们的session刷新,事务提交的时候,Hibernate才会发送一条插入数据的sql.这是因为,Hibernate是根据对象的状态来更改其数据库中对应的表的,上面所说的新建一个对象时,此时这个对象处于临时状态,而在调用了save方法之后,该对象就处于了持久化状态,此后,当Hibernate进行session刷新,事务提交后,就会将由临时状态变成了持久化状态的这个对象持久化到数据库中相应的表中。
-
具体的,对象的状态分为:
- 临时状态:
- 对象刚被new出来,没有id.
- 删除状态的对象的在session刷新,事务提交之后,也是临时状态。(此时通过在hibernate.properties文件中配置use_identifier_rollback可以是改对象的id为null)。
- 持久化状态:
- 对象有id,并且被session管理。
-
- save方法将临时对象或者游离对象变成持久化对象。
- get方法返回的时持久化的对象。
- load方法返回的是持久化对象。
- Query.list返回的是持久化对象。不过在大数据处理时需要即时清理缓存。
- update将游离对象变成持久化对象。
-
-
- 持久化状态:
- 对象有id,但是不处于session的管理之下。
-
- session.close将当前被关闭的session中的所有持久化对象全部变成游离对象。
- session.clear将当前被清理的session中的所有持久化对象全部变成游离对象。
- session.evict(Object)将指定对象变成游离对象。
- 删除状态:
- 对象有id,但是计划被删除。
-
- delete方法将持久化对象变成删除状态,但是需要在session刷新,事务提交后才会更改到数据库。
-
2.其次,MyBatis则时仍然是基于sql查询的方式,他通过将查询结果列设置到我们指定的对象的属性中,其本质上我们的对象和数据库并无直接关系,我们使用的仍然是sql。