【发问】代表ODBC、Ibatis 发问 Hibernate、Linq、Entity、JPA

分页:

多表关联查询:

多表操作

临时表:

存储过程式长语句 :

Hibernate与iBATIS的比较

博客分类:

iBATISHibernateSQL数据结构ORM

1.出身 
hibernate 是当前最流行的o/r mapping框架,它出身于sf.net,现在已经成为jboss的一部分了。 
ibatis 是另外一种优秀的o/r mapping框架,目前属于apache的一个子项目了。

2.原理 
相对hibernate“o/r”而言,ibatis是一种“sql mapping”的orm实现。hibernate 对数据库结构提供了较为完整的封装,hibernate的o/r mapping实现了pojo 和数据库表之间的映射,以及sql 的自动生成和执行。程序员往往只需定义好了pojo 到数据库表的映射关系,即可通过hibernate 提供的方法完成持久层操作。程序员甚至不需要对sql 的熟练掌握, hibernate/ojb 会根据制定的存储逻辑,自动生成对应的sql 并调用jdbc 接口加以执行。 
而ibatis 的着力点,则在于pojo 与sql之间的映射关系。也就是说,ibatis并不会为程序员在运行期自动生成sql 执行。具体的sql 需要程序员编写,然后通过映射配置文件,将sql所需的参数,以及返回的结果字段映射到指定pojo。

3.机制 
使用ibatis 提供的orm机制,对业务逻辑实现人员而言,面对的是纯粹的java对象。这一层与通过hibernate 实现orm 而言基本一致,而对于具体的数据操作,hibernate会自动生成sql 语句,而ibatis 则要求开发者编写具体的sql 语句。相对hibernate而言,ibatis 以sql开发的工作量和数据库移植性上的让步,为系统设计提供了更大的自由空间。 
hibernate与ibatis的对比:

4.学习成本 
ibatis非常简单易学,hibernate相对较复杂,门槛较高。

5.开源软件 
二者都是比较优秀的开源产品

6.二次开发 
当系统属于二次开发,无法对数据库结构做到控制和修改,那ibatis的灵活性将比hibernate更适合

7.海量数据 
系统数据处理量巨大,性能要求极为苛刻,这往往意味着我们必须通过经过高度优化的sql语句(或存储过程)才能达到系统性能设计指标。在这种情况下ibatis会有更好的可控性和表现。

8.自动化程度 
ibatis需要手写sql语句,也可以生成一部分,hibernate则基本上可以自动生成,偶尔会写一些hql。同样的需求,ibatis的工作量比 hibernate要大很多。类似的,如果涉及到数据库字段的修改,hibernate修改的地方很少,而ibatis要把那些sql mapping的地方一一修改。

9.与数据映射关系 
ibatis以数据库字段一一对应映射得到的po和hibernte这种对象化映射得到的po是截然不同的,本质区别在于这种po是扁平化的,不像hibernate映射的po是可以表达立体的对象继承,聚合等等关系的,这将会直接影响到你的整个软件系统的设计思路。

10.技术支持 
hibernate现在已经是主流o/r mapping框架,从文档的丰富性,产品的完善性,版本的开发速度都要强于ibatis

最关键的一句话是ibatis的作者说的: 
if you are starting a new project and you‘re in full control of your object model and database design, hibernate is a good choice of o/r tool. 
if you are accessing any 3rd party databases (e.g. vendor supplied), or you‘re working with a legacy database, or even just a really poorly designed database, then an o/r mapper might not be capable of handling the situation. that‘s were an sql mapper comes in handy

时间: 2024-10-07 19:17:24

【发问】代表ODBC、Ibatis 发问 Hibernate、Linq、Entity、JPA的相关文章

hibernate 出现 org.hibernate.MappingException: entity class not found 的解决办法

在Hibernate 5.0版本以上时,出现异常 org.hibernate.MappingException: entity class not found: 如果确认配置和代码都无误的情况下,可尝试增加一行代码解决: Configuration configuration = new Configuration().configure(); //增加下行代码 configuration.addClass(News.class);

ibatis 开发中的经验 (一)ibatis 和hibernate 在开发中的理解

这个项目的底层是用ibatis框架完毕,这几天也是都在用这个框架写代码,也有了一些简单的理解,把项目拿过来后基本的配置都已经配置好了,比方一些事务.日志控制等,在开发中主要用到的是写SQL语句以及熟悉ibatis xml文件都提供的一些标签,这些标签大部分是用来处理推断.逻辑,使得sql能够动态组装变的更灵活. 在写代码的工作量上ibatis要比hibernate高一些,在你写了服务层后还须要些dao层,dao层实现,然后这些在hibernate中不须要自己写,仅仅写到服务层就能够调用hiber

Ibatis和Hibernate的比较

Ibatis和Hibernate的比较 分类: IBATIS HIBERNATE2010-11-19 17:58 341人阅读 评论(0) 收藏 举报 hibernateibatis数据库sqlcachetable 我在最初的选型的时候是打算选择 Hibernate 的,在研究的过程中发现了 iBatis,经过 分析比较之后我选择了 iBatis.现在我已经使用 iBatis 完成了一个中小型的 ... - 我在最初的选型的时候是打算选择 Hibernate 的,在研究的过程中发现了 iBati

ibatis 和hibernate 在开发中的理解

这个项目的底层是用ibatis框架完成,这几天也是都在用这个框架写代码,也有了一些简单的理解,把项目拿过来后主要的配置都已经配置好了,比如一些事务.日志控制等,在开发中主要用到的是写SQL语句以及熟悉ibatis xml文件都提供的一些标签,这些标签大部分是用来处理判断.逻辑,使得sql可以动态组装变的更灵活. 在写代码的工作量上ibatis要比hibernate高一些,在你写了服务层后还需要些dao层,dao层实现,然后这些在hibernate中不需要自己写,只写到服务层就可以调用hibern

IBatis和Hibernate区别

1. 简介 Hibernate是当前最流行的O/R mapping框架.它出身于sf.net,现在已经成为Jboss的一部分了.iBATIS是另外一种优秀的O/R mapping框架,现已改名叫myBATIS.目前属于apache的一个子项目了.相对Hibernate"O/R"而言,iBATIS 是一种"Sql Mapping"的ORM实现. Hibernate对数据库结构提供了较为完整的封装,Hibernate的O/R Mapping实现了POJO和数据库表之间的

JDK注解替代Hibernate的Entity映射

1.在entity(实体类)模块中使用注解 1_1.注解的位置出现在 [类定义的前面] 和 [属性的get方法前面] Java代码: package app.entity; //模型 //注意看,导入的是jdk的拓展包 import javax.persistence.*; @Entity //告诉Spring这个类是实体类.模型类 @Table(name="t_demo") //声明这个模型对于其哪张数据表 public class Demo { private Integer ci

(转)(异常分析) org.hibernate.MappingException: entity class not found

sh整合时可能会遇到很多问题,常见的问题之一 org.hibernate.MappingException: entity class not found (实体类没有找到) 可能原因:若持久化类为:User.java 对应的hibernate映射文件为:User.hbm.xml 一般系统自动生成的映射文件为: <hibernate-mapping> <class name="User" table="...... ....... </hibernat

org.hibernate.tuple.entity.PojoEntityTuplizer 错误解决办法

org.hibernate.tuple.entity.PojoEntityTuplizer 不能instace 之前做了一个项目遇到的.出现这个问题的可能会有很多: 首先应该考虑是不是jar出现冲突. 我遇到的问题是实体类的hibernate映射文件有问题嘞,所有出现这个问题. 解决办法: 检查实体类的hibernate映射文件的异常情况

org.hibernate.HibernateException: Unable to instantiate default tuplizer [org.hibernate.tuple.entity.PojoEntityTuplizer]

使用Hibernate 插入List数据时出现了以下异常: 1 SLF4J: The requested version 1.6 by your slf4j binding is not compatible with [1.5.5, 1.5.6, 1.5.7, 1.5.8] 2 SLF4J: See http://www.slf4j.org/codes.html#version_mismatch for further details. 3 log4j:WARN No appenders co

eclipse从数据库逆向生成Hibernate实体类(eclipse中反向生成hibernate实体类+jpa注释)

eclipse从数据库逆向生成Hibernate实体类 做项目必然要先进行数据库表设计,然后根据数据库设计建立实体类(VO),这是理所当然的,但是到公司里做项目后,让我认识到,没有说既进行完数据库设计后还要再"自己"建立一变VO.意思是,在项目设计时,要么根据需求分析建立实体类,由正向生成数据库表:要么就先进行数据库表设计,再逆向生成实体类.没有说进行完任意一方的设计后再去花时间去自己匹配建立另一方的设计. 原因是: 1. 1.5倍工作量,浪费时间.(时间对公司来说很重要) 2. 无法